初探 performance – 监控网页与程序性能

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

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

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

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

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

简单解释下 performance 中的属性:

先看下一个请求发出的整个过程当中,各类环节的时间顺序:浏览器

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

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

在注释中,我用【重要】标注了我我的认为比较有用的数据,用【缘由】标注了为啥要重点关注这个数据安全

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

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

  • navigationStart
  • unloadEventStart
  • unloadEventEnd
  • domLoading
  • domInteractive
  • domContentLoadedEventStart
  • domContentLoadedEventEnd
  • domComplete
  • loadEventStart
  • loadEventEnd

新增属性:dom

  • 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 是这么测的:

其实就能够写成:

相关文章
相关标签/搜索