谈及 JavaScript 的错误处理机制,大多数开发者首先想到的便是 try...catch。它就像程序运行中的安全网,能够稳稳接住意外抛出的异常,避免整个页面或进程直接崩溃。我们用一个最简单的示例来说明:

try {
// 这里放置可能抛出错误的代码
throw new Error('出错了!');
} catch (error) {
// 这里处理错误
console.error('捕获到错误:', error.message);
}
当然,仅靠 try...catch 有时仍不足以应对所有异常,尤其是那些“漏网之鱼”。在 Node.js 环境中,你可以利用 process.on('uncaughtException') 来捕获未被任何 try...catch 兜住的异常。根据实践经验,这个机制适合作为最后一道防线,用于清理资源、记录日志或优雅地重启应用。具体代码如下:
process.on('uncaughtException', (error) => {
console.error('捕获到未处理的异常:', error.message);
// 在这里执行清理操作,然后重启应用程序
});
有一点需要特别提醒:process.on('uncaughtException') 并不能保证捕获所有错误类型,而且它的处理方式相对“激进”,容易掩盖问题的真正根源。因此,最佳实践仍然是扎实地使用 try...catch 进行逐层处理,这比事后补救要可靠得多。
此外,在异步代码场景下,错误处理的方式也可以随着代码写法一同进化。如果你采用 async/await,那么 try...catch 依然是最直接的搭档:
async function asyncFunction() {
try {
// 这里放置可能抛出错误的异步代码
throw new Error('出错了!');
} catch (error) {
// 这里处理错误
console.error('捕获到错误:', error.message);
}
}
asyncFunction();
而如果你更青睐 Promise 链式风格,那么 .catch() 就是你的得力助手:
new Promise((resolve, reject) => {
// 这里放置可能抛出错误的异步代码
throw new Error('出错了!');
}).then(() => {
// 这里处理成功的逻辑
}).catch((error) => {
// 这里处理错误
console.error('捕获到错误:', error.message);
});
总体而言,JavaScript 的错误处理工具箱相当丰富——从同步的 try...catch,到异步的 async/await 与 Promise,再到 Node.js 的全局捕获机制。关键在于根据具体场景选择合适的工具,切勿指望单一方案能应对所有情况。
