try...catch 是 JavaScript 中用于捕获运行时异常的核心机制,包含 try(执行可能出错代码)、catch(捕获并处理错误)、finally(无论成败均执行收尾操作)三部分,适用于不可控外部操作,而非可预判逻辑错误。
JavaScript 错误处理的核心机制之一就是 try...catch,它用来捕获并响应运行时发生的异常,防止程序意外中断。它不是万能的“兜底开关”,而是专为那些你无法提前预判、又必须稳住流程的场景设计的。
语法很简单,但行为很关键:
catch(e)),里面包含 e.message、e.name、e.stack 等有用信息。滥用 try...catch 反而让代码变难读、性能略降。重点看错误是否“不可控”:
if (x === undefined) 就能避免的引用错误、明显可校验的参数(比如 b === 0 就别等除零再 catch)、语法错误(这些根本进不了运行时)。不只是“包起来就完事”,几个高频技巧:
try { return JSON.parse(str); } catch { return {}; }
error instanceof TypeError 或 error.name === 'SyntaxError' 分流日志或降级策略。throw new Error('支付金额异常'),让上层统一捕获,比散落的 if 判断更清晰。.catch() 或配合 async/await 写在 try 内;直接在 try 里 await 一个没 catch 的 Promise,错误仍会冒泡出去。它不是“善后提醒”,而是可靠的执行保障:
return 123,finally 仍会执行;甚至 finally 里再写 return 456,最终函数就真返回 456。loading.close();发起请求后,不管响应如何,都要清除 pending 状态。基本上就这些。核心
就一条:try...catch 不是用来掩盖问题的,而是给不可控环节加一道可控的出口。