NgZone的简单使用

  在Angular4中,如果模板中有一些变量在组件中经常变动,比如变量foo。

<div>
  我经常变动: {{ foo }}
</div>

  在组件中它的初始值为0。

  foo = 0;

  假设在组件中有个循环,不断更新foo的值。

      for (let i = 0; i < 100; i++) {
        setInterval(() => this.counter++, 10);
      }

  那么频繁的变动将造成性能损耗。

  Angular为我们提供了NgZone服务,对于一些频繁的操作,可以不去触发变更检测。

一、使得Angular不跟踪变化

  1、在组件中引入NgZone,再将其注入。

import { NgZone } from '@angular/core';
1   constructor(
2     private zone: NgZone
3   ) { }

  2、调用runOutsideAngular方法,Angular不会对里面的变化进行跟踪。

    this.zone.runOutsideAngular(() => {
      for (let i = 0; i < 100; i++) {
        setInterval(() => this.counter++, 10);
      }
    });

setInterval每隔一秒更新foo,而此时模板中的foo将不会有变化。

二、重新跟踪变化

  如果此时又想让Angular跟踪foo的变化,用其提供的run方法。

this.zone.run(() => {
  setTimeout(() => this.foo = this.foo, 1000);
});

那么1秒后模板中的foo会得到更新。         

 

posted @ 2017-10-20 13:27  waterdrop0Oo  阅读(8778)  评论(0编辑  收藏  举报