当我订阅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时,它会按预期工作。 那么问题是什么?希望有人给出建议。
答案 0 :(得分:4)
您的期望不正确。仅console.log('--------------------')
发出3次意味着您已收到3 onNext
个事件。 forkJoin
等待所有可观察者完成。
如果您使用.do(next=>{},err=>{},complete => console.log('completed'))
查看各个流,或使用.take(1)
和/或.timeout(1000)
明确定义流的完成时间,请尝试相关操作。
发出一个值后authService..getToken()
是否完成?