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

 

转载于:https://www.cnblogs.com/steven38-27/p/7698827.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值