8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

setTimeout 与 CombineLatest 不兼容

David Mescher 2月前

24 0

我有一个动态表单,我使用多个可观察对象来加载数据。当所有可观察对象都发出值时,我想将表单设置为原始状态。唯一的问题是我的一个可观察对象在里面...

我有一个动态表单,我使用多个可观察对象来加载数据。当所有可观察对象都发出值时,我想将我的表单设置为原始状态。唯一的问题是我的一个可观察对象位于 setTimeout 内,我无法更改该部分代码。有没有其他方法可以将我的表单设置为原始状态?比如有什么方法可以让 CombineLatest 等待 setTimeout 内的可观察对象?

在这里,当所有可观察对象发出值时,我将形式设置为原始状态。

combineLatest(this.exceptionTypes$, this.currencyList$, this.priorityList$, this.dataTypeList$, this.escalationLevelList$, this.synchronisationList$)
      .subscribe(val => {this.caseOverviewForm.markAsPristine()})

这是我在 setTimeout 中最后一个可观察对象的问题,我无法改变它。这会影响最新的组合触发。

private _loadSynchronistionList(): void {
    setTimeout(() => {
      this.synchronisationList$ = of(SYNCHRONISATION_LIST).pipe(mapAndPatch(this.caseOverviewForm, FormFields.synchronisation, this.detail.id!));
    });
  }
帖子版权声明 1、本帖标题:setTimeout 与 CombineLatest 不兼容
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由David Mescher在本站《angular》版块原创发布, 转载请注明出处!
最新回复 (0)
返回
作者最近主题: