前端使用performance实现性能监控

 

计算性能指标:

可以使用Navigation.timing 统计到的时间数据来计算一些页面性能指标,比如DNS查询耗时、白屏时间、domready等等。如下:

DNS查询耗时 = domainLookupEnd - domainLookupStart
TCP链接耗时 = connectEnd - connectStart
request请求耗时 = responseEnd - responseStart
解析dom树耗时 = domComplete - domInteractive
白屏时间 = domloadng - fetchStart
domready时间 = domContentLoadedEventEnd - fetchStart
onload时间 = loadEventEnd - fetchStart


Resource timing API是用来统计静态资源相关的时间信息,performance.getEntries返回一个数组,数组的每个元素代表对应的静态资源的信息
<script>
	
(function() {

handleAddListener('load', getTiming)

function handleAddListener(type, fn) {
	if(window.addEventListener) {
		window.addEventListener(type, fn)
	} else {
		window.attachEvent('on' + type, fn)
	}
}

function getTiming() {
	try {
		var time = performance.timing;
		var timingObj = {};

		var loadTime = (time.loadEventEnd - time.loadEventStart) / 1000;

		if(loadTime < 0) {
			setTimeout(function() {
				getTiming();
			}, 200);
			return;
		}

		timingObj['重定向时间'] = (time.redirectEnd - time.redirectStart) / 1000;
		timingObj['DNS解析时间'] = (time.domainLookupEnd - time.domainLookupStart) / 1000;
		timingObj['TCP完成握手时间'] = (time.connectEnd - time.connectStart) / 1000;
		timingObj['HTTP请求响应完成时间'] = (time.responseEnd - time.requestStart) / 1000;
		timingObj['DOM开始加载前所花费时间'] = (time.responseEnd - time.navigationStart) / 1000;
		timingObj['DOM加载完成时间'] = (time.domComplete - time.domLoading) / 1000;
		timingObj['DOM结构解析完成时间'] = (time.domInteractive - time.domLoading) / 1000;
		timingObj['脚本加载时间'] = (time.domContentLoadedEventEnd - time.domContentLoadedEventStart) / 1000;
		timingObj['onload事件时间'] = (time.loadEventEnd - time.loadEventStart) / 1000;
		timingObj['页面完全加载时间'] = (timingObj['重定向时间'] + timingObj['DNS解析时间'] + timingObj['TCP完成握手时间'] + timingObj['HTTP请求响应完成时间'] + timingObj['DOM结构解析完成时间'] + timingObj['DOM加载完成时间']);

		for(item in timingObj) {
			console.log(item + ":" + timingObj[item] + '毫秒(ms)');
		}

		console.log(performance.timing);

	} catch(e) {
		console.log(timingObj)
		console.log(performance.timing);
	}
}
})();
</script>

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值