问题描述
我正在按以下方式链接Angular Http请求。问题是当第一个请求失败时,我会在错误回调中获取它,但是如果第二个请求失败,则什么也不会发生。
this.myService.requestOne(this.data)
.pipe(mergeMap(dataOne=>{
return this.myService.requestTwo(dataOne);
}))
.subscribe(dataTwo=>{
this.loading = false;
},(err)=>{
// this fires when only requestOne get Failed
this.loading = false;
});
有什么主意吗?
解决方法
这实际上还不能解决您的问题,因为您正在做的事应该可以解决。这是一些建议,可以帮助您调试正在发生的事情。在这里,我将用新错误和自定义消息替换您从任何一个流中得到的任何错误。如果抛出错误,它将被打印到控制台。
this.myService.requestOne(this.data).pipe(
catchError(err => throwError(new Error("Request One Error"))),mergeMap(dataOne =>
this.myService.requestTwo(dataOne).pipe(
catchError(err => throwError(new Error("Request Two Error")))
)
)
).subscribe({
next: _ => console.log("Stream Emission"),complete: () => console.log("Stream Completed"),error: err => console.log(err.message)
});
如果您没有得到"Request Two Error"
,则意味着requestTwo
不会引发错误,并且您的问题出在其他地方。如果您得到"Stream Completed"
,则您的代码可以正常运行而不会引发错误。