具有 ControllerAs 模式的函数被多次调用
functions with ControllerAs pattern are called multiple times
我按照angularjs样式指南中的"控制器作为"用法创建了一个控制器,其中有一个可以从视图调用的功能(例如ng-if
)。但是当我调用该函数时,似乎它被调用了三次,但我不知道它是怎么发生的。这是JSBin链接
(function() {
angular.module('app', []);
function test() {
console.log('init');
var vm = this;
vm.title = "test title";
vm.called = function() {
console.log('get called');
}
}
angular
.module('app')
.controller('test', test);
})();
<!DOCTYPE html>
<html ng-app="app">
<head>
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.3.2/angular.min.js"></script>
<meta charset="utf-8">
<title>JS Bin</title>
</head>
<body>
<div ng-controller="test as vm">
{{ vm.title }} {{ vm.called(); }}
</div>
</body>
</html>
您无法
控制计算 {{binding}}
中使用的表达式的次数。AngularJS每次认为它们的值可能已经改变时都会重新评估它们。换句话说,如果表达式包含函数调用,则每隔$digest
调用一次。
这意味着在 AngularJS 表达式中使用函数调用时,您应该非常关注性能影响。通常可以(而且更好)绑定到范围变量。如果你在一个大型应用程序中有这个,其中$rootScope.$digest
被更频繁地调用,你会看到更多对同一函数的调用。
相关文章:
- 如何从模块链中调用函数.导出到节点中
- 调用函数内部的函数
- 在javascript中调用c函数
- DropDownListFor赢得't在更改时调用函数
- Javascript页面调用函数
- 在动画结束之前调用函数
- 允许父窗口在其不同域的子iframe上调用函数
- 运行Infinite Scroll后调用函数时出现问题
- JavaScript:在调用函数的文本输入上按enter键
- 使用大括号和不使用bracs调用函数的区别
- javascript在事件上调用函数
- 从index.html调用函数,该函数无限循环
- 从带参数的字符串变量调用函数中的函数
- 为什么 JS 不在滚动时调用函数
- 是否可以在不更改上下文的情况下调用函数.apply
- 如何在ES6类中使用参数调用函数
- AngularJS:调用函数时编号不更新
- JavaScript中的立即调用函数表达式(IIFE)-传递jQuery
- 在JavaScript中调用函数时自定义此选项
- 调用函数中声明的变量