这两篇文章很好:
https://coyee.com/article/12447-how-to-write-async-await-without-try-catch-blocks-in-javascript
https://segmentfault.com/a/1190000011802045
需要注意的一点是,如果async函数里的异常是通过Promise.reject抛出来,此async函数前要加await,才能保证异常被catch; throw 无此限制。
demo
async function f() { // throw new Error('try again'); await Promise.reject('出错了'); await Promise.resolve('hello world'); // 不会执行}async function b() {try { await f();} catch(err) { console.log(err); b();}}b();
文章转载于:https://www.jianshu.com/p/753a70ae4cd3
原著是一个有趣的人,若有侵权,请通知删除
还没有人抢沙发呢~