angularjs – 获取应用程序/模块中的绑定总数

前端之家收集整理的这篇文章主要介绍了angularjs – 获取应用程序/模块中的绑定总数前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
有没有办法获得总的#绑定(通过模板'{{}}} / ng-xxx =“…”,$scope.$watch(…)等等.模块在任何时间点使用?
您应该能够使用document.getElementsByClassName(“ng-binding”).length来获得一个粗略的想法.如 here所述,此类适用于具有{{…}}或ng-bind绑定的元素,因此您可以使用绑定来获取数字或元素.它将会遗漏任何未定义的方式.

所有表达式绑定都应该使用$parse来解释表达式,这样如果您对临时度量感到满意,可以尝试在角度源代码中为此服务添加一些调试代码.创建绑定时应该很容易看到,但是当它被销毁时更难以看到.

看看当前的主人,看起来$parse将改为1.2.0,这可能会让Chrome更容易.为此,您应该能够使用Chrome开发人员工具获取堆快照(来自“配置文件”选项卡),并使用Parser构造函数搜索所有对象.

您还可以使用类似的内容查看应用中的观察者数量

var watchersPerScope = $('.ng-scope').map(function() {
  var s = $(this).scope();
  if(s.$$destroyed) return 0;
  return (s.$$watchers || 0) && s.$$watchers.length;
}).get();
var totalWatchers = 0;
for(var i=0; i<watchersPerScope.length; i++)
  totalWatchers += watchersPerScope[i];
console.log(totalWatchers);

我发现这些都不是解决你问的好方法,但它们至少是一些东西.最后一个建议是,如果出于性能原因这样做,那么Batarang for Chrome有一个非常好的性能部分.

在较新版本的angular(1.3.2)中,您也可以使用

$rootScope.$countWatchers();

如果您在页面中包含ngMock模块.参见文档here.

原文链接:https://www.f2er.com/angularjs/141274.html

猜你在找的Angularjs相关文章