async/await 是基于 Promise 的语法糖,使异步代码更易读;需用 try/catch 捕获错误,await 后必须是 Promise 或 thenable,暂停执行但不阻塞主线程。
async/await 是 JavaScript 中处理异步操作的语法糖,本质是基于 Promise 的更简洁、更易读的写法;错误处理需配合 try/catch,不能仅靠 .catch()。
它让异步代码看起来像同步代码,避免回调地狱和冗长的 .then() 链。函数加上 async 关键字后,自动返回 Promise;await 只能在 async 函数内使用,用于等待 Promise 成功(或失败)的结果。
await 不会静默吞掉错误——一旦等待的 Promise 被 reject,它会立即以异常形式抛出,必须用 try/catch 捕获。只在链尾加 .catch() 是无效的。
await someAsync().catch(...) —— 这样 catch 到的是 rejected Promise,但 await 仍会抛出异常实际开发中常结合业务逻辑做分层处理:
Promise.allSettled() 避免一个失败导致全部中断,再遍历结果分别判断 statusPromise.race([fetch(), timeout()]))几个实战中高频踩坑点:
unhandledRejection 事件,应监听并告警
or...of 可逐个等待;Promise.all() 更适合并发;避免 for 循环里直接 await 数组 map 结果(map 返回的是 pending Promise 数组,不是值)