首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >combineLatest与异步管道

combineLatest与异步管道
EN

Stack Overflow用户
提问于 2018-12-05 09:07:42
回答 1查看 2.4K关注 0票数 1

编辑了一些错误类型的

我所做的

代码语言:javascript
复制
// in component
export class WhatIdidComponent implements OnInit {
  storeData$
  combine$;

  constructor(
      private store: Store<AppState>
      private route: ActivatedRoute,
  ) {
      this.storeData$ = this.store.pipe(select((state: AppState) => state['p']['reviews']), share());
      this.combine$ = combineLatest(
         //I inserted async storeData$ variable in combineLatest
         this.storeData$,
         this.route.params.pipe(/*any operator*/)
      )
  }
}

//d

代码语言:javascript
复制
//in template.html
<ng-container *ngIf="(storeData$ | async) as data; else loading">
     // not working properly when this.storeData$ is in combineLatest
     {{data.blah}}
</ng-container>

当我在this.storeData中插入combineLatest时,storeData$ with异步管道无法工作

我认为this.storeData$与combineLatest无关。因为this.storeData$this.storeData$

但它似乎与combineLatest有关。为什么?以及如何解决这个问题?

我想要的是

  1. 正确使用this.storeData和异步管道。

感谢您的阅读

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-12-05 09:23:39

您正在创建一个具有share的多播主题,一旦订阅可观察到的combineLatest,该主题将订阅您的源(this.store)。这导致所谓的“延迟订阅者”错过了原始可观察到的通知。本例中的晚订户都是其他订户,除了第一个订户,因此您的异步管道也是。

您的选择是要么放下share管道来保持寒冷的可观察性,要么使用例如shareReplay(1)来创建缓存行为。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53628654

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档