2 回答
TA贡献1860条经验 获得超9个赞
如果你想使用 RxJS,你应该在catchError与forkJoin.
const { of, from, forkJoin } = rxjs;
const { catchError, tap } = rxjs.operators;
// your promise factory, unchanged (just shorter)
const request = {
get: url => {
return new Promise((resolve, reject) => setTimeout(
() => url === '/urlnotexists' ? reject(new Error(url)) : resolve(url), 1000
));
}
};
// a single rxjs request with error handling
const fetch$ = url => {
console.log('before:', url);
return from(request.get(url)).pipe(
// add any additional operator that should be executed for each request here
tap(val => console.log('after:', val)),
catchError(error => {
console.log('err:', error.message);
return of(undefined);
})
);
};
// concurrently executed rxjs requests
forkJoin(["/urlexists", "/urlnotexists", "/urlexists2", "/urlexists3"].map(fetch$))
.subscribe(merged => console.log("merged:", merged));
<script src="https://unpkg.com/@reactivex/rxjs@6.5.3/dist/global/rxjs.umd.js"></script>
TA贡献1789条经验 获得超10个赞
如果你愿意放弃 RXJS 而只是用 async/await 解决它是非常简单的:
const urls = ['/urlexists', '/urlnotexists', '/urlexists2', '/urlexists3']
const promises = urls.map(url => request(url)
const resolved = await Promise.allSettled(promises)
// print out errors
resolved.forEach((r, i) => {
if (r.status === "rejected') {
console.log(`${urls[i]} failed: ${r.reason})
}
})
// get the success results
const merged = resolved.filter(r => r.status === "resolved").map(r => r.value)
console.log('merged', merged)
这利用了Promise.allSettled提议的辅助方法。如果您的环境没有此方法,则可以按照此答案中所示实现它。
添加回答
举报