angular组件的变更检测策略changeDetection

属性:changeDetection   

用于当前组件的变更检测策略

@Component({
  selector: 'app-xxx',
  templateUrl: 'XXX',
  styleUrls: ['XXX'],
  changeDetection:ChangeDetectionStrategy.OnPush
})

当组件实例化之后,Angular 就会创建一个变更检测器,它负责传播组件各个绑定值的变化。 该策略有下列值:

ChangeDetectionStrategy.Default

默认策略,执行脏检查,只要值发生变化,就从父组件到子组件进行全面变更检测。检测全面,但当组件很多时,检测效率低。

ChangeDetectionStrategy.OnPush

当输入数据@Input的引用发生变化或者有事件触发时,组件才进行变更检测。检测不全面,但检测效率高。

使用ChangeDetectionStrategy.OnPush策略时,如何主动触发变更检测?

ChangeDetectorRef

它是Angular 各种视图的基础类,提供变更检测功能。 变更检测树会收集要检查的所有视图。 使用这些方法从树中添加或移除视图、初始化变更检测并显式地把这些视图标记为脏的,意思是它们变了、需要重新渲染。

它有五个方法:

markForCheck():  当视图使用 OnPush变更检测策略时,把该视图显式标记为已更改,以便它再次进行变更检测。

detach():  从变更检测树中分离开视图。 已分离的视图在重新附加上去之前不会被检查。 与 detectChanges() 结合使用,可以实现局部变更检测。

detectChanges():  检查该视图及其子视图。与 detach 结合使用可以实现局部变更检测。

checkNoChanges():  检查变更检测器及其子检测器,如果检测到任何更改,则抛出异常。

reattach():  把以前分离开的视图重新附加到变更检测树上。 视图会被默认附加到这棵树上。

使用: 

import { ChangeDetectionStrategy,ChangeDetectorRef } from '@angular/core';

@component({
    selector: 'xxx',
    exportAs: 'xxx',
    changeDetection: ChangeDetectionStrategy.OnPush
})

constructor(
    private: cdr:ChangeDetectorRef
){}

haha(){
    this.cdr.markForCheck(); //需要时调用
}

详细原理:https://www.jianshu.com/p/d8ebb6daf993?utm_campaign=haruki

                  https://juejin.im/post/6844903504218161160

                  https://juejin.im/post/6844904017836032007

                  https://blog.csdn.net/weixin_33898233/article/details/88878652

                  https://blog.csdn.net/xwnxwn/article/details/82725408

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值