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会得到更新。         

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM