TraceKit-跨浏览器堆栈跟踪日志标准化

在使用Sentry进行前端错误日志上报时,TraceKit用于标准化错误信息。由于不同浏览器对错误对象的堆栈跟踪支持不一,需要通过onerror、onunhandledrejection和try...catch等方法捕获和处理各种类型的错误。TraceKit能统一不同浏览器的错误格式,提供跨平台的错误信息标准化。使用时需注意try / catch包裹,正确引发错误,并可通过unsubscribe方法管理订阅者。了解更多详情,可查看TraceKit GitHub仓库。
摘要由CSDN通过智能技术生成

在进行前端错误日志上报时,使用了sentry,他使用TraceKit来实现错误信息标准化。为什么需要格式化?因为并非所有浏览器都支持对错误对象的堆栈跟踪,一般我们在浏览器端获取程序错误信息有如下4种:

1、onerror可以捕获到宏任务抛出的错误,微任务比如:Promise,和async函数抛出的错误是捕获不到的。

window.onerror = (msg) => {
   
  console.log('捕获到错误', msg)
}
// 可以捕获到错误
throw new Error()
// 可以捕获到错误
setTimeout(() => {
   
  throw new Error()
})
async function fn () {
   
  // 捕获不到这个错误
  throw new Error()
}
fn()
// 捕获不到这个错误
new Promise(() => {
   
  throw new Error()
})

2、对于本域的js抛出的错误,onerror包含了详情的错误信息。对于其他域的js抛出的错误,只会在msg中显示简单的 Script error。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值