繁体   English   中英

RXJS 在另一个 Observable 的 Emitted Value 上重复 Observable 的最新值

[英]RXJS Repeat latest Value of Observable on Emitted Value of another Observable

我目前正在为以下问题寻找更简单的解决方案:

一旦应用程序发出一个真实的就绪 state,我想重复一个 observable 的最新值。 有没有更简单的方法,而无需像以下解决方案中使用 rxjs 运算符创建额外的临时主题? 我无法与这些创建工作组合。

当前没有 rxjs 运算符的解决方案:

private repeatWhenReady<T>(obs: Observable<T>): Observable<T> {
  // store.select returns the observable of the ready State
  const readyObs = this.store.select(state => state.ready).pipe(first(ready => ready=== true));
  const resultSubject = new Subject<T>();
  let lastValue: T;
  let lastValueSet = false;
  let ready = false;
  const complete = () => resultSubject.complete();

  obs.subscribe((value) => {
    if (!ready) {
      lastValue = value;
      lastValueSet = true;
    } else {
      resultSubject.next(value);
    }
  }, complete, complete);

  readyObs.subscribe(() => {
    ready = true;
    if (lastValueSet) {
      resultSubject.next(lastValue);
    }
  });

  return resultSubject.asObservable();
}

您可以尝试使用 withLatestFrom 运算符。

private repeatWhenReady<T>(obs: Observable<T>): Observable<T> {
  return this.store.select(state => state.ready)
.pipe(
first(ready => !!ready), // filter your ready value with true
withLatestFrom(obs),  // take last value of your observable
map(([first, second]) => { // map observable pipe to second value 
    return second;
  })
);
}

你可以在这里访问。

[https://www.learnrxjs.io/learn-rxjs/operators/combination/withlatestfrom][1]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM