我知道这个问题在这里之前已经被问过。但是接受的解决方案对我不起作用,或者我无法很好地理解它。
我正在使用 ng-7 我有简单的用例:
我有 2 个 API,第 2 个取决于第 1 个的响应。我订阅了第一个 API 的结果,然后使用管道订阅了第二个 API 结果。
我的代码如下所示;
this._SomeService
.addUserToDb(payload)
.pipe(
map(res => res),
mergeMap(db1Response =>
this._SomeService.addUserToDb2(db1Response
)
),
catchError(errodb1 => {
return Observable.throw(new
Error(errorSso));
})
)
.subscribe(
resDb2 => {
// Here I get response of addUserToDb2
},
errDb2 => {
}
)
现在在订阅第二个 API 响应之前,我想订阅另一个 observable 说:
this._tokenService.getToken.pipe(
)
并想在服务 2 中使用它的响应。这样:
API1 => 令牌 => API2
请建议如何实施。
更新:
我试图实现,下面是我的实现:
this._service.addUserToDB1(payload).pipe(
map(resp => this.resDB1 = resp) // Adding to global variable because I need this response while subscribing to DB2 service.
,mergeMap(resdb1=>this._tokenService.getToken.pipe(
mergeMap(token => this._service.addUserToDb2(
this.resDB1,
this.organizationId,
this.practitionerId,
token
),
catchError(errorToken => {
return Observable.throw(new Error(errorToken));
})),
)
),
catchError(errordb1 => {
return Observable.throw(new Error(errordb1));
})
).subscribe (
resdb2Response =>
{
},
errdb2 => {
}
)
有人可以验证上述实施是否可行或建议正确的方法吗?