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怎么提高运气,aapoker透视脚本下载,手段教程(有挂攻略)-哔哩哔哩所有...
解谜透视!hardrock作必... 解谜透视!hardrock作必弊!好像是真的有辅助教程(证实有挂)-哔哩哔哩1、超多福利:超高返利,...
详细透视!agpoker辅助,... 详细透视!agpoker辅助,hhpoker透视工具,步骤教程(有挂讲解)-哔哩哔哩hhpoker透...
普及透视!hardrock作必... 普及透视!hardrock作必弊!切实一直总是有辅助app(竟然有挂)-哔哩哔哩暗藏猫腻,小编详细说...
揭幕透视!红龙poker有辅助... 揭幕透视!红龙poker有辅助吗,哈糖大菠萝有挂吗,练习教程(真的有挂)-哔哩哔哩揭幕透视!红龙po...
详细透视!pokemmo修改器... 详细透视!pokemmo修改器手机版!一直真的是有辅助工具(有挂方法)-哔哩哔哩1、许多玩家不知道p...
总结透视!hhpoker是内部... 总结透视!hhpoker是内部控制吗,aapoker怎么开辅助器,操作教程(有挂功能)-哔哩哔哩hh...
教你透视!pokemmo辅助器... 教你透视!pokemmo辅助器手机版下载!一直是有辅助软件(详细教程)-哔哩哔哩1、每一步都需要思考...
辅助透视!sohoo辅助,po... 辅助透视!sohoo辅助,pokemmo脚本辅助下载,项目教程(有挂详细)-哔哩哔哩1、实时poke...
解密透视!智星德州有脚本吗!好... 解密透视!智星德州有脚本吗!好像真的有辅助软件(今日头条)-哔哩哔哩小薇(辅助器软件下载)致您一封信...