Ответ 1
вы можете сделать это так же, как и вы, вызовите "дерегистрация" внутри вашей функции:
var unbind = $scope.$watch("tag", function () {
// ...
unbind();
});
Я знаю, что вы можете отвязать часы $так:
var listener = $scope.$watch("tag", function () {});
// ...
listener(); // would clear the watch
но вы можете отвязать часы в объявлении функции часов. Итак, после того, как часы выполняются один раз, он откручивает себя? Что-то вроде:
$scope.$watch("tag", function () {
unbindme()
});
вы можете сделать это так же, как и вы, вызовите "дерегистрация" внутри вашей функции:
var unbind = $scope.$watch("tag", function () {
// ...
unbind();
});
Поскольку выражение tag
является выражением, вы можете использовать одноразовую привязку, чтобы отменить привязку после получения значения:
$scope.$watch("::tag", function () {});
angular
.module('app', [])
.controller('example', function($scope, $interval) {
$scope.tag = undefined
$scope.$watch('::tag', function(tag) {
$scope.tagAsSeen = tag
})
$interval(function() {
$scope.tag = angular.isDefined($scope.tag) ? $scope.tag + 1 : 1
}, 1000)
})
angular.bootstrap(document, ['app'])
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.4.0/angular.min.js"></script>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<title>JS Bin</title>
</head>
<body ng-controller="example">
Tag: {{tag}}
<br>
Watch once result: {{tagAsSeen}}
</body>
</html>
bindonce директива, возможно, что вам нужно.
var unbindMe=$scope.$watch('tag',function(newValue){
if(newValue){
unbindMe()
}
})