性能监控一直是前端的一个重点工作,本文介绍在做性能监控时,必须要了解的一个Web API——performance,主要了解它的的属性和使用。
一、**
window.performance
**
1、
Performance
是一个标准,用于解决开发者在浏览器中获取性能数据的问题。
2、
Performance
同时也是一个浏览器全局对象,提供了一组 API 用于获取程序在某些节点的性能数据。它包含一组高精度时间定义,以及配套的相关方法。
通过performance对象可以获取到当前页面中与性能相关的信息。
属性值说明
eventCounts
:记录了所有已经分发过的 Event,处理时间是否大于 50ms。memory
: 记录内存属性- usedJSHeapSize,JS 对象(包括V8引擎内部对象)占用的内存- totalJSHeapSize,可使用的内存- jsHeapSizeLimit,内存大小限制navigation
:返回一个 PerformanceNavigation 对象,这个对象表示出现在当前浏览上下文的 navigation 类型,比如获取某个资源所需要的重定向次数- redirectCount:只读,表示在到达这个页面之前重定向了多少次- onresourcetimingbufferfull:当浏览器的资源时间性能缓冲区已满时会触发- type:表示是如何导航到这个页面的,一般用来检测页面时如何跳转过来的。
值含义0当前页面是通过点击链接,书签和表单提交,或者脚本操作,或者在url中直接输入地址,type值为01点击刷新页面按钮或者通过window.location.reload() 方法显示的页面2页面通过历史记录和前进后退访问时255其他方式进入的页面timeOrigin
:返回性能测量开始时的时间的高精度时间戳。timing
:最重要的属性,包含了网络、解析等一系列的时间数据,常用于页面性能分析。一张图来了解timing,如下:常用性能指标计算公式:DNS查询耗时 = domainLookupEnd - domainLookupStart
TCP链接耗时 = connectEnd - connectStart
request请求耗时 = responseEnd - responseStart
解析dom树耗时 = domComplete - domInteractive
白屏时间 = domloading - fetchStart
domready时间 = domContentLoadedEventEnd - fetchStart
onload时间 = loadEventEnd - fetchStart
使用注意事项:
因为很多值必须在页面完全加载之后才能得出,建议最好在window.onload事件中读取各种数据。
使用示例:
// 兼容性写法const performance = window.performance || window.msPerformance || window.webkitPerformance;const timing = performance && performance.timing;const navigation = performance && performance.navigation;// DNS 解析耗时const dns = timing.domainLookupEnd - timing.domainLookupStart;// TCP 链接耗时const conn = timing.connectEnd - timing.connectStart;// 等待服务器响应耗时(注意是否存在cache)const request = timing.responseStart - timing.requestStart;// 内容加载耗时(注意是否存在cache)const response = timing.responseEnd - timing.responseStart;// 总体网络交互耗时,即开始跳转到服务器资源下载完成const network = timing.responseEnd - timing.navigationStart;// 渲染处理const processing =(timing.domComplete || timing.domLoading)- timing.domLoading;// 抛出load事件const load = timing.loadEventEnd - timing.loadEventStart;// 总耗时const total =(timing.loadEventEnd || timing.loadEventStart || timing.domComplete || timing.domLoading)-
timing.navigationStart;// 可交互const active = timing.domInteractive - timing.navigationStart;// 请求响应耗时,即T0,注意cacheconst t0 = timing.responseStart - timing.navigationStart;// 首次出现内容,即T1const t1 = timing.domLoading - timing.navigationStart;// 内容加载完毕,即T3const t3 = timing.loadEventEnd - timing.navigationStart;// 重定向次数const redirectCount = navigation && navigation.redirectCount;// 跳转耗时const redirect = timing.redirectEnd - timing.redirectStart;// APP CACHE 耗时const appcache = Math.max(timing.domainLookupStart - timing.fetchStart,0);
更多属性说明可参看:https://segmentfault.com/a/1190000040912772
二、
performance.getEntries()
window.performance.getEntries()
返回一个数组,数组的每个元素代表对应的静态资源的信息。
数组的第一个元素结果相当于:
window.performance.getEntriesByType('navigation')
window.performance.getEntries() 执行结果:
window.performance.getEntriesByType(‘navigation’) 执行结果:
发现其实是一样的!
重要属性说明:
duration
:资源的总耗时(包括等待时长,请求时长,响应时长 相当于responseEnd - startTime)initiatorType
:初始类型(注意这个类型并不准确,例如在css中的图片资源会这个值显示css,所以还是推荐用name中的后缀名)name
:资源的链接transferSize
: 转换后的文件大小(略大于encodedBodySize,这个值是和chrome的devtool Network里的size一致)
PS:了解更多可点击查看 使用 Performance API 获取页面性能 、参考文章
版权归原作者 英子的搬砖日志 所有, 如有侵权,请联系我们删除。