TAT.felix 初探 performance – 监控网页与程序性能
In 未分类 on 2015年09月03日 by view: 43,012
13

使用 window.performance 提供了一组精确的数据,经过简单的计算就能得出一些网页性能数据。

配合上报一些客户端浏览器的设备类型等数据,就可以实现简单的统计啦!

额,先看下兼容性如何:http://caniuse.com/#feat=nav-timing

这篇文章中 Demo 的运行环境为最新的 Chrome 的控制台,如果你用的是其他浏览器,自查兼容性哈~

先来看看在 Chrome 浏览器控制台中执行 window.performance  会出现什么:

简单解释下 performance 中的属性:

先看下一个请求发出的整个过程中,各种环节的时间顺序:

具体的含义都在注释里说明了,接下来我们看下能用这些数据做什么?

使用 performance.timing 信息简单计算出网页性能数据

在注释中,我用【重要】标注了我个人认为比较有用的数据,用【原因】标注了为啥要重点关注这个数据

使用 performance.getEntries() 获取所有资源请求的时间数据

这个函数返回的将是一个数组,包含了页面中所有的 HTTP 请求,这里拿第一个请求 window.performance.getEntries()[0]  举例。 注意 HTTP 请求有可能命中本地缓存,所以请求响应的间隔将非常短 可以看到,与 performance.timing 对比: 没有与 DOM 相关的属性:

  • navigationStart

  • unloadEventStart

  • unloadEventEnd

  • domLoading

  • domInteractive

  • domContentLoadedEventStart

  • domContentLoadedEventEnd

  • domComplete

  • loadEventStart

  • loadEventEnd

新增属性:

  • name

  • entryType

  • initiatorType

  • duration

与 window.performance.timing 中包含的属性就不再介绍了:

可以像 getPerformanceTiming  获取网页的时间一样,获取某个资源的时间:

使用 performance.now() 精确计算程序执行时间

performance.now()  与 Date.now()  不同的是,返回了以微秒(百万分之一秒)为单位的时间,更加精准。

并且与 Date.now()  会受系统程序执行阻塞的影响不同,performance.now()  的时间是以恒定速率递增的,不受系统时间的影响(系统时间可被人为或软件调整)。

注意 Date.now()  输出的是 UNIX 时间,即距离 1970 的时间,而 performance.now()  输出的是相对于 performance.timing.navigationStart(页面初始化) 的时间。

使用 Date.now()  的差值并非绝对精确,因为计算时间时受系统限制(可能阻塞)。但使用 performance.now()  的差值,并不影响我们计算程序执行的精确时间。

使用 performance.mark() 也可以精确计算程序执行时间

使用 performance.mark()  标记各种时间戳(就像在地图上打点),保存为各种测量值(测量地图上的点之间的距离),便可以批量地分析这些数据了。

直接上示例代码看注释便明白:

可以看到,for  循环 measureRandomFunc888  的时候

结束时间为: 4875.1199999969685

开始时间为:4875.112999987323

执行时间为:4875.1199999969685 - 4875.112999987323 = 0.00700000964

标记和测量用完了可以清除掉:

当然 performance.mark()  只是提供了一些简便的测量方式,比如之前我们测量 domReady 是这么测的:

其实就可以写成:

抛砖引玉:performance 数据能干啥用?

熟悉 Chrome 开发者工具的朋友应该知道:在开发环境下,其实我们自己打开 Chrome 的开发者工具,切换到网络面板,就能很详细的看到网页性能相关的数据。但当我们需要统计分析用户打开我们网页时的性能如何时,我们将 performance 原始信息或通过简单计算后的信息 (如上面写到的 getPerformanceTiming()  和 getEntryTiming()) 上传到服务器,配合其他信息(如 HTTP 请求头信息),就完美啦~

原创文章转载请注明:

转载自AlloyTeam:http://www.alloyteam.com/2015/09/explore-performance/

  1. johe 2020 年 2 月 1 日

    学习了 真的很不错的一篇文章

  2. 肥翔 2018 年 4 月 8 日

    performance.now() 返回的是毫秒吧,只是小数点后面的值能精确到微秒

  3. aleewr 2017 年 4 月 15 日

    返回数据 domComplete 都为 0.

  4. 自由自在的我77 2016 年 12 月 25 日

    // 计算程序执行的精确时间 function getFunctionTimeWithDate (func) { var timeStart = Data.now(); // 执行开始 func(); // 执行结束 var timeEnd = Data.now(); // 返回执行时间 return (timeEnd – timeStart);} 写错了吧,应该是 Date.now() 吧

  5. vell0120 2016 年 10 月 17 日

    问下怎么可以拿到资源大小呢?

  6. 橄榄123 2016 年 7 月 23 日

    请教几个问题:1. 页面加载时间:performance.timing.loadEventEnd – performance.timing.navigationStart;2.Time-line 里面的 Range 时间 3.NetWork 里面的 Finish 时间三者有什么关系?

  7. zyg 2016 年 1 月 7 日

    深深吐槽一下 代码 阅读体验真心不好

  8. 冯瑞_FR 2015 年 11 月 4 日

    [good]

  9. joy 2015 年 10 月 15 日

    hello。请问 window.performance.now() 返回的时间是当前时间的微秒值还是当前时间与 navigationStart 对应时间差值?

    • TAT小赖 2015 年 10 月 15 日

      文中有写噢:『performance.now() 输出的是相对于 performance.timing.navigationStart(页面初始化) 的时间』

    • TAT小赖 2015 年 10 月 15 日

      你在浏览器中 console 一下也便知。

  10. TAT.felix

    TAT小赖 2015 年 10 月 8 日

  11. 鲁国人 2015 年 9 月 18 日

    学习了!赞

发表评论