Angular RXJS forkJoin完成进度

标签 angular typescript rxjs

我想在我的 Angular 应用程序中为批量 HTTP 请求设置一个进度计数器。我使用 forkJoin 来执行 Observables 数组。管道只执行一次。对于 obs 变量中的 X 个请求,它不会执行。在 forkJoin 中获取完整的 Observable 是否有其他方法?

这是我尝试过的:

    let obs: Observable<any>[] = [...];
    let counter: number = 0;
    // obs has 5 items here.
    forkJoin(obs)
    .pipe(
      tap(() => {
        counter++;
      })
    )
    .subscribe(res => {
    })
    .add(() => {
      loadingRef.close(loadingRef);
      this.refresh();
      // Counter only equals 1 here.
      // It should equal 5.
    });

最佳答案

您可以通过添加管道来转换可观察对象,如下所示:

forkJoin(this.obs.map(o => o.pipe(tap(() => this.count++))))
    .subscribe();

好吧,计数的过程非常颠簸,但这是一种解决方案

the stackblitz

关于Angular RXJS forkJoin完成进度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58328087/

相关文章:

angularjs - Angular 指令未在 ES6 中编译

angular - 等待两个 observables 在 Angular auth guard 中按顺序完成

rxjs - ngrx效果错误处理

javascript - 检查 JS 或 TS 中的标识符中是否存在字符串值

angular 的@input 与 viewchild 用于从父组件向子组件发送数据

Angular:观察两种状态但只执行一次

html - 如何将 cdkDropList 的元素放入 div 中?

angular - ngFor block 内模板中的异步管道触发 http GET 调用循环

angular - 使用 Angular/RXJS 一个接一个地发送两个 HTTP 请求,其中第二个请求需要第一个?

javascript - 嵌套 Firebase 查询