- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
在分析我的 angularjs 应用程序时,我发现有时 $get.Scope.$eval
需要超过 100 毫秒。在单个 $digest 循环中,至少有 3 个长的 $get.Scope.$eval
案例,我想优化这部分。
在探查器的 $get.Scope.$eval
下方,我看到仅调用了 angularjs 代码。
这是个人资料图表的屏幕截图。
任何人都可以建议,这是怎么回事以及如何优化这部分?我想这可能是由 ng-repeat
、ng-include
或 ng-if
引起的,但我不确定。
更新:这是我的 application 的简化结构.可能问题出在我的应用程序的体系结构中。该应用程序主要在单一路由上工作并且仅在 3 种情况下更改它,因此应用程序将状态存储在全局 Controller AppController
- 胖 Controller 中。 html 中还有 20k+ 个节点,并且数量可以增长(我看到的最大值是 60k)
最佳答案
$eval 在解析 Angular 表达式时由 Angular 内部使用,例如 {{variable}}
。在没有看到任何代码的情况下,很难判断哪些表达式在不必要地使用资源,但通常太大或嵌套的 ng-repeat
(或许多 ng-
指令包含在ng-repeat
) 是一种代码味道。
Angular 使用脏检查来评估这些表达式(因为没有更好的选择)——这意味着每次您使用 {{}}
语法创建绑定(bind)时,它都会创建一个隐式的 $watch获取该值的表达式,将在每个摘要周期调用以查看该值是否已更改(在更改时重新生成 DOM 的相关部分)。
这是我过去成功使用的一项优化:
大多数时候,当您使用 {{}}
绑定(bind)一个值时,您实际上并不期望该值发生变化(如标签),而这种 2 向数据绑定(bind)是完全多余。从 Angular 版本 1.3 开始,您可以选择 create one-time bindings使用 ::
语法:
One-time expressions will stop recalculating once they are stable, which happens after the first digest if the expression result is a non-undefined value
这消除了此类绑定(bind)的相应性能开销。 (如果您使用的是较旧的 Angular 版本,外部库可以模仿这种行为,例如 bindonce 。)
以下是我在分析/优化 Angular 应用程序时发现的一些有用的其他工具:
This stackoverflow answer ,提供了一个简洁的解决方案来计算您的页面上有多少观察表达式处于事件状态。一条经验法则是,如果您超过 2000,您将开始注意到性能问题,并且您应该考虑更改您的架构 - 采用延迟加载机制,重新考虑您是否真的需要所有绑定(bind)等。
在生产环境中 disabling the default "debug mode" of angular也有助于提高性能。
关于javascript - AngularJS:$eval 需要很多时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31695829/
在我看来 eval()受到与 goto 相同的蔑视。由 eval ,我的意思是将字符串作为代码执行的函数,如在 PHP、Python、JavaScript 等中看到的。是否有使用 eval() 的情况
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
我有几十个条件(例如,foo > bar)需要在 DataFrame 的 ~1 MM 行上进行评估,最简洁的方法编写此代码是为了将这些条件存储为字符串列表,并创建 bool 结果的 DataFrame
我正在创建一种编译为字节码并在自定义 VM 上运行的小型语言,其架构在很大程度上受到了我所阅读的有关 Python 和 Lua 的影响。有两个堆栈 - 一个存储函数参数、局部变量和临时值的数据堆栈,以
我正在尝试运行此代码: var aaa = await page.$$eval(selector, list => (list, value) => { return reso
我知道标题听起来很复杂,但为了保持动态,这是有目的的;) 示例(请注意,假定这些示例代码位于外部 eval 内) //Ex1 this works eval('function test (){}')
这是交易,我们有一个很大的 JS 库需要压缩,但是 YUI compressor如果发现“eval”语句,它不会完全压缩代码,因为担心它会破坏其他东西。这很好,但是我们确切地知道什么正在被评估,所以我
每门计算机科学类(class)中都讲授过这一点,并且在许多书籍中都写到程序员不应使用 GoTo。甚至还有一个 xkcd关于它的漫画。我的问题是我们是否达到了可以对 Eval 说同样的事情的地步? Go
这两种方法中的一种是否必须被优先使用,还是仅取决于口味? #!/usr/bin/env perl use warnings; use strict; use DBI; my $db = 'sqlite
如果存在“eval()”,uglify 不会破坏变量。命令行: uglifyjs script/script.js --compress --mangle --unsafe/path/to/scrip
我刚刚开始使用 Julia。我正在尝试使用 eval(在 Julia 中)来在函数中定义一组变量。假设我想将 v1 设置为 2: function fun_test(varargs...) v1
这个问题在这里已经有了答案: When is JavaScript's eval() not evil? (27 个答案) 关闭2 年前。 我从未遇到过需要 eval() 的情况。 人们常常说 []
这个问题在这里已经有了答案: "Variable" variables in JavaScript (9 个回答) Use dynamic variable names in JavaScript
好的 - 我有一个非常具体的案例,我需要使用 eval()。在人们告诉我我根本不应该使用 eval() 之前,让我透露一下我知道 eval 的性能问题、安全问题和所有这些问题。我在非常狭窄的情况下使用
我的问题是关于 JavaScript 闭包和 Eval() 函数。 我有一些看起来像这样的代码,还有一些其他 jQuery 插件相关的代码没有显示。如果需要,我可以用更多代码更新问题。 var _Cu
...或者有更好的方法来实现记忆化吗? Function.memoize = function(callableAsString) { var r = false, callable,
当我尝试在jmeter中执行以下代码时: import org.json.JSONArray; import org.json.JSONObject; String jsonString = prev
根据Mozilla docs为了使用 eval 执行函数,它必须被包装在 ( ) 中,即如果您不使用它们,那么它将被视为字符串. eval as a string defining function
标题看起来很蠢,但我不知道如何准确表达,抱歉。 我有一个程序需要评估一些用户代码(通过 RestrictedPython 以确保安全),并且我想将一个函数放入评估的全局变量中,以便它可以在评估时向我打
以下需要在函数范围内,因为在交互式控制台模式下不会发生奇怪的行为。 以下函数按预期返回 5 (function() { var x = 5; return eval("x"); })() 一个简单透明
我是一名优秀的程序员,十分优秀!