前端错误监控

本文是学习慕课网上课程前端跳槽面试必备技巧的学习笔记,便于之后复习。本文从以下几个方面说明错误监控:

1.前端错误的分类

2.错误的捕获方式

3.上报错误的基本原理

1.前端错误的分类

即时运行错误: 一般是代码错误

资源加载错误:图片、js、css等资源加载失败

2.错误的捕获方式

即时运行错误的捕获方式:

  1. try…catch
  2. window.onerror只能捕获即时运行错误,不能捕获资源加载错误。因为资源加载错误,并不会向上冒泡,object.onerror捕获后就会终止,所以window.onerror并不能捕获资源加载错误
// try-catch
try{

}catch(err=>{
    console.log(err)
})
// winodw.onerror
window.onerror = function(msg, url, line)    
{            
    console.log( "错误信息:"+msg+ "\n所在文件:"+ url  + "\n错误行号:" + line);  
}

资源加载错误的捕获方式:

  1. object.onerror    img标签、script标签都可以添加onerror事件,用来捕获资源加载错误;
  2. performance.getEntries()  返回的将是一个数组,数组的每个元素代表对应的静态资源的信息,包含了页面中所有的已成功加载 HTTP 请求,可以与预期加载资源比较,通过这种方式,可以间接的拿到没有加载的资源错误。

         例如:

// 显示出来的资源就是已经成功加载的
performance.getEntries().forEach(function(item){console.log(item.name)})
// 显示出所有的img集合,这是所有需要加载的图片的集合
document.getElementsByTagName('img')

document.getElementsByTagName('img')获取的资源数组减去通过performance.getEntries()获取的资源数组,剩下的就是没有成功加载的,这种方式可以间接的捕获到资源加载错误。

     3.Error事件捕获   资源加载错误,虽然会阻止冒泡,但是不会阻止捕获。

首先在body中请求一个不存在的文件:


	
	

使用Error事件捕获:


如下图,成功捕获到错误

延伸提问:跨域的js运行错误可以捕获吗,错误提示是什么,应该怎么处理?

可以捕获到错误,但是错误的具体信息(如出错行号、出错详情)不能拿到

处理:步骤一:在script标签增加crossorigin属性,客户端

步骤二:设置js资源响应http头上加Access-Control-Allow-Origin:*/域名,服务端

3.上报错误的基本原理

使用AJAX通信方式上报

利用Image对象上报 // 推荐使用


如下图,请求成功发出

 

 

 

 

 

你可能感兴趣的:(前端,错误监控,错误捕获)