繁体   English   中英

如何在完成 Rxjs Observable 之前等待 subscribe 中定义的异步方法?

[英]How to await an asynchonous method defined inside subscribe before to complete an Rxjs Observable?

让我们看看下面的代码:

myObservable.subscribe({
  next: async () => {
    await something();
  },
  complete: () => {
    console.log('All async task are comlpeted');
  }
});

问题是console.log在最后next被触发后被调用,但我希望它在最后一个something()完成后被调用。

有没有办法做到这一点?

我指定我自己使用new Obsercable(observer =>...)实现了myObservable 所以可以修改。

我要么 a) 坚持 observable 配方,并将 promise 转换为 observable,或者 b) 坚持 promise/async-await 模式,并将 observable 转换为 promise。 坦率地说,我不知道如何成功地混合这两者。

基于 Rx 的解决方案:

import { from } from 'rxjs';
import { finalize } from 'rxjs/operators';

myObservable.pipe(
    switchMap(() => from(something()),
    finalize(() => console.log('All async task are comlpeted')),
).subscribe(someFunction);

暂无
暂无

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

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