ChangeDetection状态检测策略

一.什么是ChangeDetection用于检测程序内部状态,然后反映到UI上引起状态变化的内容【通常都是异步的】:Events事件触发、XHR发送的Http等请求通过接收内容改变某些状态、Timers定时任务事件执行通常是通过ApplicationRef监听NgZone的onTurnDone,然后执行检测程序状态通常会构建CD树(ChangeDetection树),Ang...
摘要由CSDN通过智能技术生成

一.什么是ChangeDetection

  • 用于检测程序内部状态,然后反映到UI上

  • 引起状态变化的内容【通常都是异步的】:Events事件触发、XHR发送的Http等请求通过接收内容改变某些状态、Timers定时任务

  • 事件执行通常是通过ApplicationRef监听NgZone的onTurnDone,然后执行检测

  • 程序状态通常会构建CD树(ChangeDetection树),Angular默认策略是将所有的CD树都跑一边,有的属性只会通过外部因素改变而改变的通常会执行onPush策略(只跑基本的节点)

在这里插入图片描述

二.Default策略调整为OnPush策略实例代码
  • 在Component组件中,如果没有定义@Component中的changeDetection,则默认为ChangeDetectionStrategy.Default策略

    @Component({
        selector:'app-test',
        ...,
        changeDetection: ChangeDetectionStrategy.Default
    })
    
  • 可以人为将CD策略变成onPush策略,表示告诉angular不用来检查我,除非我外部发生变化

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值