使用Javascript监控前端相关数据的代码
本篇文章介绍了Javascript监控前端相关数据,项目开发完成外发后,没有一个监控系统,我们很难了解到发布出去的代码在用户机器上执行是否正确,所以需要建立前端代码性能相关的监控系统。
所以我们需要做以下的一些模块:
一、收集脚本执行错误
functionerror(msg,url,line){
varREPORT_URL="xxxx/cgi";//收集上报数据的信息
varm=[msg,url,line,navigator.userAgent,+newDate];//收集错误信息,发生错误的脚本文件网络地址,用户代理信息,时间
varurl=REPORT_URL+m.join('||');//组装错误上报信息内容URL
varimg=newImage;
img.onload=img.onerror=function(){
img=null;
};
img.src=url;//发送数据到后台cgi
}
//监听错误上报
window.onerror=function(msg,url,line){
error(msg,url,line);
}
通过管理后台系统,我们可以看到页面上每次错误的信息,通过这些信息我们可以很快定位并且解决问题。
二、收集html5performance信息
performance包含页面加载到执行完成的整个生命周期中不同执行步骤的执行时间。performance相关文章点击如下:使用performanceAPI监测页面性能
计算不同步骤时间相对于navigationStart的时间差,可以通过相应后台CGI收集。
function_performance(){
varREPORT_URL="xxxx/cgi?perf=";
varperf=(window.webkitPerformance?window.webkitPerformance:window.msPerformance),
points=['navigationStart','unloadEventStart','unloadEventEnd','redirectStart','redirectEnd','fetchStart','domainLookupStart','connectStart','requestStart','responseStart','responseEnd','domLoading','domInteractive','domContentLoadedEventEnd','domComplete','loadEventStart','loadEventEnd'];
vartiming=pref.timing;
perf=perf?perf:window.performance;
if(perf&&timing){
vararr=[];
varnavigationStart=timing[points[0]];
for(vari=0,l=points.length;i<l;i++){
arr[i]=timing[points[i]]-navigationStart;
}
varurl=REPORT_URL+arr.join("-");
varimg=newImage;
img.onload=img.onerror=function(){
img=null;
}
img.src=url;
}
通过后台接口收集和统计,我们可以对页面执行性能有很详细的了解。
三、统计每个页面的JS和CSS加载时间
在JS或者CSS加载之前打上时间戳,加载之后打上时间戳,并且将数据上报到后台。加载时间反映了页面白屏,可操作的等待时间。
<script>varcssLoadStart=+newDate</script>
<linkrel="stylesheet"href="xxx.css"type="text/css"media="all">
<linkrel="stylesheet"href="xxx1.css"type="text/css"media="all">
<linkrel="stylesheet"href="xxx2.css"type="text/css"media="all">
<sript>
varcssLoadTime=(+newDate)-cssLoadStart;
varjsLoadStart=+newDate;
</script>
<scripttype="text/javascript"src="xx1.js"></script>
<scripttype="text/javascript"src="xx2.js"></script>
<scripttype="text/javascript"src="xx3.js"></script>
<script>
varjsLoadTime=(+newDate)-jsLoadStart;
varREPORT_URL='xxx/cgi?data='
varimg=newImage;
img.onload=img.onerror=function(){
img=null;
};
img.src=REPORT_URL+cssLoadTime+'-'+jsLoadTime;
</script>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支