Handle Error in RxJs flatMap stream and continue processing
我正在Angular 2应用程序中使用RxJ来从API并行获取多个页面的数据,并保存任何失败的请求以供将来重试。
为此,我想捕获由flatMap-ing http get请求(下面的代码)生成的错误,并继续进行进一步的流处理。如果发生错误,我当前的解决方案将导致流中断。
1 2 3 4 5 6 7 8 9 10 | Rx.Observable.range(1, 5) .flatMap(pageNo => { params.set('page', ''+pageNo); return this.http.get(this.API_GET, params) .catch( (err) => { //save request return Rx.Observable.throw(new Error('http failed')); }); }) .map((res) => res.json()); |
比方说,上例中,第2页和第3页的HTTP请求失败。我想为这两个请求处理错误(保存失败的请求以后重试),并让其他请求继续并映射到json()。
我尝试使用
在您的捕获内,不要返回
如果要将信息传播到外部流,则可以使用
或将错误记录在
换句话说,只需将其链接:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | const stream$ = Rx.Observable.range(1, 5) .flatMap(num => { return simulateRest(num) .catch(error => { console.error(error); return Rx.Observable.empty(); }); }); stream$.subscribe(console.log); // mocking-fn for simulating an error function simulateRest(num) { if (num === 2) { return Rx.Observable.throw("Error for request:" + num); } return Rx.Observable.of("Result:" + num); } |
1 | <script src="https://unpkg.com/rxjs/bundles/Rx.min.js"> |