Angular应用程序使用未定义的observable不会导致ExpressionChangedAfterItHasBeenCheckedError错误,但它看起来应该会?
创始人
2024-10-30 14:00:24
0

在Angular中,当某个observable的值发生更改时,Angular会运行变更检测器以更新视图。这时可能会遇到ExpressionChangedAfterItHasBeenCheckedError错误,因为更改还没有完全渲染到视图上。

然而,当使用undefinedobservable时,Angular不会运行变更检测器,因为未定义的observable并没有发出任何值。因此,即使值发生更改,Angular也不会更新视图,也不会出现ExpressionChangedAfterItHasBeenCheckedError错误。

以下是示例代码如何创建undefinedobservable和如何订阅它:

import { Component, OnInit } from '@angular/core';
import { Observable } from 'rxjs';

@Component({
  selector: 'app-my-component',
  template: `
    
{{ value$ | async }}
`, }) export class MyComponent implements OnInit { value$: Observable; ngOnInit() { // Create an undefined observable this.value$ = undefined; // Subscribe to the undefined observable this.value$.subscribe(console.log); // This will not cause ExpressionChangedAfterItHasBeenCheckedError } }

要避免这种情况,可以在创建observable时使用of方法来发出默认值。例如:

import { Component, OnInit } from '@angular/core';
import { Observable, of } from 'rxjs';

@Component({
  selector: 'app-my-component',
  template: `
    
{{ value$ | async }}
`, }) export class MyComponent implements OnInit { value$: Observable; ngOnInit() { // Create an observable with a default value this.value$ = of(''); // Subscribe to the observable this.value$.subscribe(console.log); // This will not cause ExpressionChangedAfterItHasBeenCheckedError } }

相关内容

热门资讯

透视教程书!wepoker脚本... 透视教程书!wepoker脚本,wepoker免费脚本弱密码(透视)竟然真的有挂(哔哩哔哩)1、每一...
透视诀窍!德州透视是真的假的,... 透视诀窍!德州透视是真的假的,hhpoker哪个俱乐部靠谱(透视)都是是有挂(哔哩哔哩)1、透视诀窍...
透视妙计!wepoker辅助器... 透视妙计!wepoker辅助器安装包,hhpoker一直输有挂吗(透视)好像真的有挂(哔哩哔哩)1、...
透视项目!wepoker私人局... 透视项目!wepoker私人局辅助挂,wepoker辅助软件视频(透视)好像存在有挂(哔哩哔哩)1、...
透视举措!wepoker免费脚... 透视举措!wepoker免费脚本咨询,pokemmo修改器手机版(透视)其实是真的挂(哔哩哔哩)1、...
透视方案!wpk作必弊最怕三个... 您好,如何判断wpk辅助软件的真假这款游戏可以开挂的,确实是有挂的,需要了解加去威信【1367043...
透视指引!pokerworld... 透视指引!pokerworld辅助器,wepoker透视脚本免费下载(透视)本来有挂(哔哩哔哩)we...
透视机巧!hhpoker透视脚... 透视机巧!hhpoker透视脚本,红龙poker作必弊指令(透视)其实存在有挂(哔哩哔哩)红龙pok...
透视绝活!拱趴大菠萝作必弊方法... 透视绝活!拱趴大菠萝作必弊方法,拱趴大菠萝十三水作必弊(透视)总是是真的透视技巧(哔哩哔哩)1、操作...
透视演示!wpk俱乐部是做什么... 透视演示!wpk俱乐部是做什么的,aapoker如何设置胜率(透视)切实真的有挂(哔哩哔哩)1、wp...