考虑下面的例子:为什么AngularJS过滤器只运行一次?
angular.module('app', []).controller('TestController', function($scope) {
$scope.getText = function() {
console.log('getting text');
return 'text';
};
}).filter('text', function() {
return function() {
console.log('text filter');
return 'text';
};
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.2/angular.min.js"></script>
<div ng-app="app" ng-controller="TestController">
<p>{{getText()}}</p>
<p>{{'' | text}}</p>
</div>
注意,getText()
函数运行两次而过滤器仅运行一次。我假设getText()
函数运行两次以确保模型现在稳定。为什么过滤器的行为不一样?