Angular异步管道在可观察对象改变时不会刷新。
创始人
2024-10-30 12:00:20
0

Angular的异步管道确实不会在可观察对象发生改变时自动刷新。然而,我们可以使用一些技巧来解决这个问题。以下是一种可能的解决方案:

  1. 创建一个自定义管道,用于包装异步管道。
import { Pipe, PipeTransform, ChangeDetectorRef } from '@angular/core';
import { Observable } from 'rxjs';
import { tap } from 'rxjs/operators';

@Pipe({
  name: 'refresh',
  pure: false // 设置pure为false以确保管道在每个变化检测周期中都会被调用
})
export class RefreshPipe implements PipeTransform {
  constructor(private cdr: ChangeDetectorRef) {}

  transform(value$: Observable): Observable {
    return value$.pipe(
      tap(() => this.cdr.markForCheck()) // 使用ChangeDetectorRef手动触发变化检测
    );
  }
}
  1. 在模板中使用自定义的刷新管道。
{{ observableValue$ | async | refresh }}

通过将可观察对象传递给refresh管道,我们可以确保在可观察对象发生变化时刷新视图。

这种方法的关键点在于将ChangeDetectorRef注入到自定义管道中,并在管道内部使用markForCheck方法手动触发变化检测。这将导致Angular重新计算管道,并正确刷新视图。

相关内容

热门资讯

透视辅助!wpk私人局辅助是真... 透视辅助!wpk私人局辅助是真的吗,wepoker辅助器官方(透视)有挂教程(存在有挂)-哔哩哔哩所...
透视免费!wepoker破解版... 透视免费!wepoker破解版内购,hhpoker到底可以辅助码(透视)专业教程(有挂方针)-哔哩哔...
透视科技!拱趴大菠萝万能挂图解... 透视科技!拱趴大菠萝万能挂图解,hhpoker怎么开透视(透视)分享教程(真实有挂)-哔哩哔哩1)拱...
透视透视挂!拱趴大菠萝辅助神器... 透视透视挂!拱趴大菠萝辅助神器,红龙poker有辅助吗(透视)必备教程(有挂功能)-哔哩哔哩1、完成...
透视能赢!德普之星辅助工具如何... 透视能赢!德普之星辅助工具如何设置,约局吧是否有挂(透视)必备教程(有挂教学)-哔哩哔哩1)德普之星...
刚刚!wepoker辅助器软件... 刚刚!wepoker辅助器软件下载,wepoker私人局怎么玩(透视)解密教程(有挂规律)-哔哩哔哩...
受玩家影响!佛手在线大菠萝为什... 受玩家影响!佛手在线大菠萝为什么都输,pokemmo免费脚本(透视)总结教程(有挂透明挂)-哔哩哔哩...
透视好牌!wepoker祈福有... 透视好牌!wepoker祈福有用吗,wepoker公共底牌(透视)辅助教程(确实有挂)-哔哩哔哩1、...
出现新变化!hhpoker到底... 出现新变化!hhpoker到底可以辅助码,hhpoker为什么一直输(透视)揭幕教程(真是有挂)-哔...
透视教程!德普之星透视辅助,s... 透视教程!德普之星透视辅助,sohoopoker辅助(透视)揭露教程(讲解有挂)-哔哩哔哩1)德普之...