promise中reject和throw的使用

javascript 复制代码
async function promiseThrow() {
  return new Promise((resolve, reject) => {
    throw new Error("promise error"); 
  });
}
//这样会正常处理
async function promiseThrow() {
  return new Promise(async (resolve, reject) => {
    throw new Error("promise error"); 
  });
}
//这样会出错,外部无法捕获

1. 不使用 async 关键字的 Promise 构造函数回调函数

ts 复制代码
async function promiseThrow() {
 return new Promise((resolve, reject) => { throw new Error("promise error"); }); 
}
promiseThrow().catch((error) => { console.error("Caught error:", error.message); });

在这个例子中,Promise 构造函数的回调函数内部直接 throw new Error("promise error")。虽然这是一个同步错误,但由于它发生在 Promise 构造函数的执行环境中,JavaScript 引擎会将这个错误封装成一个 rejected Promise,并将其关联到返回的 Promise 实例上。因此,外部通过 .catch 方法可以正常捕获这个错误。 2. 使用 async 关键字的 Promise 构造函数回调函数

ts 复制代码
async function promiseThrow() {
 return new Promise(async (resolve, reject) => { throw new Error("promise error"); }); 
} 
promiseThrow().catch((error) => { console.error("Caught error:", error.message); });

在这个例子中,Promise 构造函数的回调函数是一个 async 函数。当 throw new Error("promise error") 执行时,它会生成一个 rejected Promise,但这个 rejected Promise 并未被 Promise 构造函数捕获和处理。由于 async 函数内部的错误被转换为 rejected Promise,这个 rejected Promise 只会在 async 函数返回的 Promise 中体现出来,而 Promise 构造函数本身并未等待这个内部 async 函数的结果。因此,外部的 .catch 无法捕获到这个错误,导致程序意外终止。

结论:

  • 当在不使用 async 关键字的 Promise 构造函数回调函数中 throw 错误时,错误会被 Promise 机制捕获并转换为 rejected Promise,外部的 .catch 可以正常捕获这个错误。
  • 当在使用 async 关键字的 Promise 构造函数回调函数中 throw 错误时,由于 async 函数返回的 Promise 被忽略了,错误实际上未被 Promise 构造函数捕获,导致外部的 .catch 无法捕获,程序意外终止。

对于这种情况,正确的做法是避免在 Promise 构造函数回调函数中使用 async 关键字,或者在 async 回调函数内部使用 reject 来传递错误,如下所示:

ts 复制代码
async function promiseThrow() {
 return new Promise((resolve, reject) => { reject(new Error("promise error")); }); 
} 
// 或者 
async function promiseThrow() {
 return new Promise((resolve, reject) => { const innerPromise = async () => { throw new Error("promise error"); 
};
innerPromise().then(resolve, reject); }); } 
// 外部捕获错误 
promiseThrow().catch((error) => { console.error("Caught error:", error.message); });
相关推荐
霍理迪16 分钟前
CSS盒模型布局规则
前端·javascript·css
千寻girling31 分钟前
面试官: “ 说一下 JS 中什么是事件循环 ? ”
前端·javascript
程序员龙语33 分钟前
CSS 高级选择器应用
前端·css
Cassie燁34 分钟前
el-table源码解读2-2——createStore()初始化方法
前端·javascript·vue.js
程序员修心36 分钟前
CSS文本样式全解析:11个核心属性详解
前端·css
旧梦吟1 小时前
脚本网站 开源项目
前端·web安全·网络安全·css3·html5
北极糊的狐1 小时前
按钮绑定事件达成跳转效果并将树结构id带入子页面形成参数完成查询功能并将返回的数据渲染到页面上2022.5.29
前端·javascript·vue.js
幽络源小助理1 小时前
幽络源二次元分享地址发布页源码(HTML) – 源码网免费分享
前端·html
全栈前端老曹1 小时前
【ReactNative】页面跳转与参数传递 - navigate、push 方法详解
前端·javascript·react native·react.js·页面跳转·移动端开发·页面导航
用泥种荷花2 小时前
【前端学习AI】Python环境搭建
前端