RxJS forkJoin没有完成

时间:2017-11-23 08:21:27

标签: angular rxjs rxjs5

当我订阅getAllSubModules时,forkJoin执行所有这些observable而没有错误但是没有完成。我知道forkJoin只有在所有的observable完成之后才能完成,但作为证据,我在控制台中看到'-----'3次,确认一切都成功,所以它的所有可观察结果都已完成。

 getSubmodules(id): Observable<any> {
    return this.authService.getToken()
      .flatMap((token) => this.http.get(`${this.URL}/ROS/applications/modules/${id}/subModules?token=${token}`))
      .map((res: any) => res.data.map((subModule) => this.mapSubModules(subModule)));
  }
  getAllSubmodules(): Observable<any> {
    const tasks = [];
    this.modules.forEach((module: AppModule) => {
      const obs = this.getSubmodules(module.id).map((subModules) => {
        this.allSubModules[module.id] = subModules;
        console.log('--------------------');
      });
      tasks.push(obs);
    });
    return Observable.forkJoin(...tasks).retry(2);
  }
  mapSubModules(moduleData) {
    if (moduleData.id) {
      const subModule = <SubModule> {
        id: moduleData.id,
        parentId: moduleData.parentId,
        typeId: moduleData.typeId,
        name: moduleData.name.az,
        active: true
      };
      return subModule;
    }
  }

使用 forkJoin

时,不会执行此代码
 this.universityService.getAllSubmodules().subscribe(() => {             
        // --- Below is not executed!--
        console.log('subModules in Report Co');
        console.log(this.universityService.allSubModules);
        this.checkUrl();
        this.showChild = true;
      }, (er) => console.log(er));

但是当我使用 combineLatest 而不是forkJoin时,它会按预期工作。  那么问题是什么?希望有人给出建议。

1 个答案:

答案 0 :(得分:4)

您的期望不正确。仅console.log('--------------------')发出3次意味着您已收到3 onNext个事件。 forkJoin等待所有可观察者完成。

如果您使用.do(next=>{},err=>{},complete => console.log('completed'))查看各个流,或使用.take(1)和/或.timeout(1000)明确定义流的完成时间,请尝试相关操作。

发出一个值后authService..getToken()是否完成?