Angular-当OnPush策略被触发时如何进行变更检测?
创始人
2024-10-21 03:30:33
0

使用 @Input() 和 ChangeDetectorRef

使用 OnPush 策略将组件标记为仅在输入属性发生更改时才进行变更检测。

但如果您想要手动通知组件进行更改检测,例如在处理异步数据时,您可以使用 ChangeDetectorRef。

以下是一个示例:

组件类:

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

@Component({
  selector: 'my-component',
  template: `{{ name }}`,
  changeDetection: ChangeDetectionStrategy.OnPush
})
export class MyComponent {
  @Input() name: string;

  constructor(private cdr: ChangeDetectorRef) {}

  updateName() {
    setTimeout(() => {
      this.name = 'John';
      // 手动触发变更检测
      this.cdr.detectChanges();
    }, 1000);
  }
}

在上面的例子中,我们使用 @Input() 来接收父组件传递的数据,并使用 OnPush 策略来在输入属性发生更改时进行变更检测。

我们还定义了一个 updateName() 方法,在该方法中使用 setTimeout() 模拟一个异步操作,并将组件的 name 属性更改为 'John'。

因为我们使用了 OnPush 策略,更新 name 属性并不会触发变更检测。因此,我们使用 ChangeDetectorRef 手动触发变更检测。

父组件模板:



在父组件中,我们将 name 属性绑定到子组件的输入属性,并使用一个按钮来触发 updateName() 方法,从而更新子组件的 name 属性并手动触发变更检测。

相关内容

热门资讯

透视揭露!wepoker辅助脚... 透视揭露!wepoker辅助脚本,wepoker私人局透视-确实是真的有辅助神器(哔哩哔哩)1、下载...
透视科普!wpk透视是真的假的... 透视科普!wpk透视是真的假的,wpk软件是正规的吗-真是存在有辅助软件(哔哩哔哩)1、金币登录送、...
透视解密!wepoker辅助真... 透视解密!wepoker辅助真的假的,We poker辅助器下载-真是真的有辅助神器(哔哩哔哩)亲,...
透视推荐!hhpoker辅助软... 透视推荐!hhpoker辅助软件,hhpoker德州有挂吗-果然是有辅助神器(哔哩哔哩)1、模拟器是...
透视科普!wpk透视是真的假的... 透视科普!wpk透视是真的假的,wpk辅助器是真的吗-真是是真的有辅助攻略(哔哩哔哩)1、有没有辅助...
透视曝光!wepoker可以透... 透视曝光!wepoker可以透视码,wejoker内置辅助-本来有辅助教程(哔哩哔哩)1、该软件可以...
透视揭露!wepoker破解工... 透视揭露!wepoker破解工具,wepoker怎么设置盖牌-本来一直总是有辅助方法(哔哩哔哩)1、...
透视有挂!有哪些免费的wpk作... 透视有挂!有哪些免费的wpk作弊码,wpk辅助器是真的吗-果然一直总是有辅助脚本(哔哩哔哩)1、公共...
透视关于!德扑圈透视挂,德普之... 透视关于!德扑圈透视挂,德普之星透视辅助-好像是真的有辅助软件(哔哩哔哩)脚本下载中分为三种模型:挂...
透视解密!德普辅助器怎么用,德... 透视解密!德普辅助器怎么用,德普之星透视-好像是有辅助app(哔哩哔哩)1、完成辅助器v3.3的残局...