# 慢速计算

在每个变更检测周期上,Angular 都会同步进行:

  • 除非另有指定,否则会根据每个组件的检测策略估算所有组件中的所有模板表达式

  • 执行 ngDoCheckngAfterContentCheckedngAfterViewCheckedngOnChanges生命周期钩子。模板中的单个慢速计算或生命周期钩子可能会减慢整个变更检测过程,因为 Angular 会按顺序运行计算。

# 识别慢速计算

你可以用 Angular DevTools 的分析器来识别繁重的计算。在性能时间线中,单击一个栏以预览特定的变更检测周期。这将显示一个条形图,该图显示了框架在每个组件的变更检测上花了多长时间。当你点击一个组件时,你可以预览 Angular 花了多长时间来评估其模板和生命周期钩子。

Angular DevTools profiler preview showing slow computation 比如,在上面的屏幕截图中,选择了所记录的第二个变更检测周期,其中 Angular 在这个周期花费了超过 573 毫秒,大部分时间都花在了 EmployeeListComponent上。在详细信息面板中,你可以看到 Angular 花了超过 297 毫秒的时间来估算 EmployeeListComponent的模板。

# 优化慢速计算

有几种技术可以消除慢速计算:

  • 优化底层算法。这是推荐的方法。如果你可以加快导致问题的算法的速度,则可以加快整个变更检测机制。

  • 使用纯管道进行缓存。你可以将繁重的计算移动到纯管道中。与 Angular 上一次调用它时相比,只有在检测到其输入发生更改时,Angular 才会重新估算纯管道。

  • 使用记忆化(memoization)。记忆化是一种与纯管道类似的技术,不同之处在于纯管道仅保留计算中的最后一个结果,而记忆化可以存储多个结果。

  • 避免在生命周期钩子中触发重绘/回流。某些操作会导致浏览器同步重新计算页面布局或重新渲染它。由于回流和重绘通常很慢,因此你要避免在每个变更检测周期中都执行它们。

纯管道和记忆化有不同的权衡。与记忆化相比,纯管道是 Angular 的内置概念,记忆化是一种用于缓存函数结果的通用软件工程实践。如果你使用不同的参数频繁调用繁重的计算,则记忆化的内存开销可能会很大。

Last Updated: 5/16/2023, 7:35:10 PM