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'、运行时异常如 ReferenceError、TypeError)。
常见可捕获场景:
- 函数内直接调用不存在的方法:
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网络失败、图片onerror、script加载失败等资源类错误
如何补全错误捕获能力
靠单一 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.onerror 和 unhandledrejection 的回调参数结构不同,前者有 message, url, line, col, error,后者是 event.reason + event.promise。
容易忽略的关键细节
很多开发者以为加了 try...catch

-
fetch成功返回 404/500 响应?这不是 JS 异常,try...catch不触发,得靠response.ok或response.status判断 - React/Vue 组件渲染时报错?默认不会冒泡到
try,需用componentDidCatch或errorCaptured钩子 - 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该如何做?

