news 2026/4/3 1:53:53

Promise 未捕获 reject 错误处理指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Promise 未捕获 reject 错误处理指南

当 Promise 被 reject 且未处理时,浏览器会显示 "Uncaught (in promise)" 错误。


本文介绍了三种常见未处理情况:

  • 直接 reject
  • async 函数抛出错误
  • then 链中未捕获的错误

提供了四种处理方法:

  • 使用 .catch()
  • try...catch
  • Promise 构造函数内部捕获
  • 全局事件监听(unhandledrejection)

最佳实践建议始终为 Promise 添加错误处理,包括使用空 catch 处理不关心的结果,以及使用 Promise.allSettled 处理并行操作。


这些方法能有效防止应用因未处理的 Promise 错误而崩溃,同时改善调试体验。


关联阅读推荐

JavaScript Promise 总结(附:常见返回 Promise 的API,ServiceWorker 中 Promise)


Promise 未捕获 reject 错误处理指南


当 Promise 被 reject 且没有相应的错误处理时,浏览器控制台确实会显示警告/错误。


具体表现

在 Chrome DevTools 中,你会看到类似这样的错误:

Uncaught (in promise) Error: Something went wrong at <anonymous>:1:20

为什么会出现这个警告?


Promise 的设计哲学是:每个 reject 都应该被处理。


如果 reject 没有被捕获,JavaScript 引擎认为这可能是一个未被注意的错误。


示例代码

// 情况1:直接 reject 没有被处理 const promise1 = new Promise((resolve, reject) => { reject(new Error('Something went wrong')); }); // 控制台会显示:Uncaught (in promise) Error: Something went wrong // 情况2:async 函数中 throw 没有被捕获 async function failedAsync() { throw new Error('Async error'); } failedAsync(); // 同样会显示未捕获的 promise 错误 // 情况3:then 链中的 reject 没有被后续的 catch 处理 Promise.resolve() .then(() => { throw new Error('Error in then'); }); // 这里虽然看起来有 then,但没有 catch,所以错误仍未被捕获

如何正确处理?

1.使用.catch()

promise .then(result => { // 处理成功情况 }) .catch(error => { // 处理 reject 和 then 中抛出的错误 console.error('Caught error:', error); });

2.使用try...catch处理 async/await

async function handleAsync() { try { await someAsyncFunction(); } catch (error) { console.error('Caught error:', error); } }

3.在 Promise 构造函数中捕获错误

const safePromise = new Promise((resolve, reject) => { try { // 可能出错的代码 const result = riskyOperation(); resolve(result); } catch (error) { reject(error); } });

4.全局捕获未处理的 Promise 错误

// 在浏览器中 window.addEventListener('unhandledrejection', event => { console.warn('未处理的 Promise 拒绝:', event.reason); event.preventDefault(); // 阻止默认的控制台错误 }); // 在 Node.js 中 process.on('unhandledRejection', (reason, promise) => { console.log('未处理的拒绝:', reason); });

最佳实践建议

  1. 总是为 Promise 链添加错误处理

  2. 在 async 函数中总是使用 try...catch

  3. 对于不关心结果的 Promise,至少加上一个空的 catch

    someAsyncOperation().catch(() => {});
  4. 对于可能失败的多个并行操作,使用Promise.allSettled

    const results = await Promise.allSettled(promises); results.forEach(result => { if (result.status === 'rejected') { console.log('失败:', result.reason); } });

这样可以确保你的应用不会因为未处理的 Promise 错误而崩溃,同时也能获得更好的调试体验。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/15 2:02:22

ARM 架构中的CurrentEL

ARM 架构中的CurrentEL 文章目录 ARM 架构中的CurrentEL一、基本概念二、异常级别&#xff08;Exception Level&#xff09;背景三、CurrentEL寄存器格式四、访问方式五、实际应用场景六、与其他相关寄存器的关系七、权限和限制八、调试和开发中的用途九、示例代码&#xff1a;…

作者头像 李华
网站建设 2026/3/27 16:10:18

细胞电生理仿真软件:GENESIS_(8).神经网络建模

神经网络建模 在细胞电生理仿真软件中&#xff0c;神经网络建模是一个重要的研究方向。GENESIS&#xff08;General Neuronal Simulation System&#xff09;提供了一系列强大的工具和功能&#xff0c;用于构建和模拟复杂的神经网络模型。本节将详细介绍如何在GENESIS中进行神…

作者头像 李华
网站建设 2026/3/21 16:21:40

AI赋能软件工程毕设:8款工具实现论文撰写与代码生成自动化

文章总结表格&#xff08;工具排名对比&#xff09; 工具名称 核心优势 aibiye 精准降AIGC率检测&#xff0c;适配知网/维普等平台 aicheck 专注文本AI痕迹识别&#xff0c;优化人类表达风格 askpaper 快速降AI痕迹&#xff0c;保留学术规范 秒篇 高效处理混AIGC内容&…

作者头像 李华
网站建设 2026/3/16 18:07:32

ArcGIS Python零基础脚本开发教程--- 11.2ArcPy错误处理:ExecuteError异常详解

在地理处理过程中,正确处理错误是保证脚本稳定运行的关键。今天我们来深入探讨ArcPy中最常见的错误类型——ExecuteError。 🔍 什么是ExecuteError? ExecuteError是ArcPy中的一个异常类,专门用于捕获地理处理工具执行过程中发生的错误。 核心特点: 自动触发:只要地理处…

作者头像 李华
网站建设 2026/3/27 12:56:00

MySQL 序列

MySQL 序列 引言 MySQL 序列是一种常用的数据库对象,用于生成连续的数值。在数据库设计中,序列可以用于实现自增主键、订单编号、日志ID等多种场景。本文将详细介绍 MySQL 序列的概念、使用方法以及注意事项。 MySQL 序列的概念 MySQL 序列是一种特殊的表,用于生成连续的…

作者头像 李华
网站建设 2026/3/10 1:06:39

墨蝌签名平台保姆级使用教程(www.moooke.com/)下

使用墨蝌如何签名应用&#xff1f; 1、进入签名页后&#xff0c;点击上传文件 2、选中要签名的文件后&#xff0c;双击文件进行上传或者拖拽文件到上传框 3、上传文件后&#xff0c;选择证书和插件&#xff08;插件可不选&#xff09;&#xff0c; 4、证书和插件都选择完毕后&…

作者头像 李华