我读过一些关于Change Detection的关于角的好文章,并且对它是什么以及它是如何工作的有了一些很好的理解。但是到目前为止,我读到的每一篇文章都只关注Change Detection,当组件上发生了一些事件,或者某些input属性发生了变化等等。我还没有找到任何一篇关于当route发生变化时会发生什么的文章。在这种情况下,Change Detection是如何工作的?另外,无论是将所有HTML/DOM更新一次性推送到浏览器,还是一旦发现任何DOM更新,它都会不断地向浏览器提供信息吗?
发布于 2017-11-23 20:49:52
路由不会触发更改检测。它所做的唯一特定于更改检测的事情是检验标记 (正在激活的路由器出口组件):
@Directive({selector: 'router-outlet', exportAs: 'outlet'})
export class RouterOutlet implements OnDestroy, OnInit {
...
activateWith(activatedRoute: ActivatedRoute, resolver: ComponentFactoryResolver|null) {
...
// Calling `markForCheck` to make sure we will run the change detection when the
// `RouterOutlet` is inside a `ChangeDetectionStrategy.OnPush` component.
this.changeDetector.markForCheck();
this.activateEvents.emit(this.activated.instance);
}路由器由某些事件、UI或其他(setTimeout、XHR)等导航,这些事件被NgZone拦截,一旦代码执行完,更改检测过程就会启动。
另外,无论是将所有HTML/DOM更新一次性推送到浏览器,还是一旦发现任何DOM更新,它都会不断地向浏览器提供信息吗?
它通过每个组件逐个更新DOM元素。对于更改检测的最全面解释,请参阅以下所有条款:
https://stackoverflow.com/questions/47462800
复制相似问题