javascript错误如何捕获_try_catch能处理所有异常吗【教程】

发布时间 - 2026-01-29 00:00:00    点击率:
try...catch 仅能捕获同步代码中当前执行栈抛出的 Error 实例,如 undefined.foo()、throw new Error()、JSON.parse('{') 等;无法捕获语法错误、异步错误、Promise 拒绝、资源加载失败等。

try...catch 不能处理所有 JavaScript 异常,它只捕获同步代码中抛出的错误,对异步错误、语法错误、资源加载失败、未捕获的 Promise 拒绝等完全无效。

哪些错误 try...catch 能捕获

仅限当前执行栈中同步抛出的 Error 实例(包括 throw new Error()throw 'msg'、运行时异常如 ReferenceErrorTypeError)。

常见可捕获场景:

  • 函数内直接调用不存在的方法:undefined.foo()
  • 手动抛错:throw new TypeError('invalid')
  • JSON 解析失败:JSON.parse('{') // SyntaxError

示例:

try {
  JSON.parse('{');
} catch (e) {
  console.log(e instanceof SyntaxError); // true
}

哪些错误 try...catch 完全捕获不到

这些错误脱离了当前 try 块的执行上下文,或发生在 JS 引擎解析/编译阶段,无法被拦截:

  • 顶层语法错误(如 const 后少写分号导致解析失败)——直接报 SyntaxError,不进任何 try
  • 异步回调中的错误:setTimeout(() => { throw new Error(); }, 0)
  • Promise 拒绝未处理:Promise.reject('oops')(不触发 catch,但会触发 unhandledrejection 事件)
  • fetch 网络失败、图片 onerrorscript 加载失败等资源类错误

如何补全错误捕获能力

靠单一 try...catch 必然漏掉大量真实异常,必须组合使用以下机制:

  • 全局监听:window.addEventListener('error', handler) 捕获未被捕获的同步错误和资源加载错误(注意:不能捕获 Promise 错误)
  • Promise 错误统一处理:window.addEventListener('unhandledrejection', e => { ... })e.reason 是拒绝原因
  • 异步操作显式包裹:async function foo() { try { await api() } catch (e) { ... } }
  • 第三方脚本错误兜底:在 标签加 onerror 属性,或用 window.onerror(兼容性更好但信息较少)

注意:window.onerrorunhandledrejection 的回调参数结构不同,前者有 message, url, line, col, error,后者是 event.reason + event.promise

容易忽略的关键细节

很多开发者以为加了 try...catch

就高枕无忧,实际线上最常报错的恰恰是它管不了的几类:

  • fetch 成功返回 404/500 响应?这不是 JS 异常,try...catch 不触发,得靠 response.okresponse.status 判断
  • React/Vue 组件渲染时报错?默认不会冒泡到 try,需用 componentDidCatcherrorCaptured 钩子
  • Webpack 打包后代码行号错乱?source-map 未正确上传时,error.stack 几乎不可读
  • 跨域脚本错误(如 CDN 资源)会被浏览器屏蔽堆栈信息,只留 "Script error."

真正健壮的错误监控,从来不是靠一个语法块,而是靠分层捕获 + 上报归因 + source map 还原 —— try...catch 只是其中最表层的一环。


# vue  # react  # javascript  # java  # js  # json  # 浏览器  #   # ai  # win  # cdn  # 跨域  # 组件渲染  # webpack  # try  # throw  # catch  # Error  # const  #   # Event  # map 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何使用 jQuery 正确渲染 Instagram 风格的标签列表  HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法  如何在万网自助建站中设置域名及备案?  Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)  Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权  魔方云NAT建站如何实现端口转发?  Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践  英语简历制作免费网站推荐,如何将简历翻译成英文?  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  微信小程序 配置文件详细介绍  制作电商网页,电商供应链怎么做?  如何快速搭建虚拟主机网站?新手必看指南  移动端脚本框架Hammer.js  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】  非常酷的网站设计制作软件,酷培ai教育官方网站?  Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】  教学论文网站制作软件有哪些,写论文用什么软件 ?  如何在云主机快速搭建网站站点?  Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决  QQ浏览器网页版登录入口 个人中心在线进入  北京专业网站制作设计师招聘,北京白云观官方网站?  Linux系统运维自动化项目教程_Ansible批量管理实战  如何在局域网内绑定自建网站域名?  动图在线制作网站有哪些,滑动动图图集怎么做?  Laravel项目怎么部署到Linux_Laravel Nginx配置详解  Laravel如何使用模型观察者?(Observer代码示例)  打造顶配客厅影院,这份100寸电视推荐名单请查收  Bootstrap CSS布局之列表  详解Android中Activity的四大启动模式实验简述  html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  Laravel怎么使用Intervention Image库处理图片上传和缩放  android nfc常用标签读取总结  Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤  php在windows下怎么调试_phpwindows环境调试操作说明【操作】  音乐网站服务器如何优化API响应速度?  网站建设保证美观性,需要考虑的几点问题!  如何在企业微信快速生成手机电脑官网?  Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制  手机软键盘弹出时影响布局的解决方法  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?