Angular移除不必要的$watch之性能优化

......(原文请点击原文出处查看)

再回到上面所提的性能问题。

如果有太多watcher函数,那么在每次$digest循环时,肯定会慢下来,这就是Angular“脏检查机制”的性能瓶颈。在社区中有个经验值,如果超过2000个watcher,就可能感觉到明显的卡顿,特别在IE8这种老旧浏览器上。有什么好的方案可以解决这个问题呢?最明显的方案是:减少$watch,尽量移除不必要的$watch

慎用$watch和及时销毁

要想提高Angular页面的性能,那么在开发的时候,就应该尽量减少显式使用$scope.$watch函数,Angular中的很多内置指令已经能够满足大部分的业务需求。特别是如果能复用ng内置的UI事件指令(ngChange、ngClick…),那么就不要添加额外的$watch。

对于不再使用的$watch,最好尽早将其释放,$scope.$watch函数的返回值就是用于释放这个watcher的函数,如下面的单次绑定实现(one-time)

angular.module('com.ngnice.app')
.controller('DemoController', ['$scope', function($scope) {  var vm = this;  vm.count = 0;  var textWatch = $scope.$watch('demo.updated', function(newVal, oldVal) {    if (newVal !== oldVal) {      vm.count++;      textWatch();    }  });  return vm;}]);

未完待续。。。有点事先忙

你可能感兴趣的:(Angular移除不必要的$watch之性能优化)