• 初探performance.timing API


    浏览器新提供的performance接口精确的告诉我们当访问一个网站页面时当前网页每个处理阶段的精确时间(timestamp),以方便我们进行前端分析。

    它是浏览器的直接实现,比之前在网页中用js设置Date.time或者cookie来分析网页时间上要精确很多。

    以下是w3c提供的performance.timing各阶段api图

    暂时的缺点:

    Navigation Timing stops at the window.onload event

    现代的网站很多是在onload之后再发触发更多的异步请求,而navigation Timing统计却只在window.onload之后就不统计了 。

    为什么不在所有的网络请求完成后统计timing呢?

    因为要考虑到有些网页有轮询或者长链接的情况。所以情况就复杂了,w3c还在草案阶段。如果你够牛想出好的解决方案,也可以直接发邮件到w3c去,贡献你的一份力量。

    为方便查看统计值,自己写了一个简单的统计表插件

    performanceTracer

    performance API 耗时统计

    统计点:

    readyStart = timing.fetchStart - timing.navigationStart;
    redirectTime = timing.redirectEnd  - timing.redirectStart;
    appcacheTime = timing.domainLookupStart  - timing.fetchStart;
    unloadEventTime = timing.unloadEventEnd - timing.unloadEventStart;
    lookupDomainTime = timing.domainLookupEnd - timing.domainLookupStart;
    connectTime = timing.connectEnd - timing.connectStart;
    requestTime = timing.responseEnd - timing.requestStart;
    initDomTreeTime = timing.domInteractive - timing.responseEnd;
    domReadyTime = timing.domComplete - timing.domInteractive; //过早获取时 domComplete有时会是0
    loadEventTime = timing.loadEventEnd - timing.loadEventStart;
    loadTime = timing.loadEventEnd - timing.navigationStart;//过早获取时 loadEventEnd有时会是0

    结果:

    console.log('准备新页面时间耗时: ' + readyStart);
    console.log('redirect 重定向耗时: ' + redirectTime);
    console.log('Appcache 耗时: ' + appcacheTime);
    console.log('unload 前文档耗时: ' + unloadEventTime);
    console.log('DNS 查询耗时: ' + lookupDomainTime);
    console.log('TCP连接耗时: ' + connectTime);
    console.log('request请求耗时: ' + requestTime);
    console.log('请求完毕至DOM加载: ' + initDomTreeTime);
    console.log('解释dom树耗时: ' + domReadyTime);
    console.log('load事件耗时: ' + loadEventTime);
    console.log('从开始至load总耗时: ' + loadTime);

    使用方法:

    可以直接在html底部引入performance-min.js

    或下载chrome 插件.crx包,

    注意事项

    由于window.performance.timing还处于w3c完善过程中,当你的网站有异步请求时,请在所有异步请求完成后再点击chrome上的插件按钮,以确保数据正确

    效果图:

    =======================================================================

    js及chrome插件下载地址

    github: https://github.com/willian12345/performanceTracer

    关于performance timing 未完善功能老外的讨论:http://www.stevesouders.com/blog/2012/10/30/qa-nav-timing-and-post-onload-requests/

    ==========================

    bug修复 :

    现chrome下可以安装插件了,mac与win下已测试,其它系统上应该也可以安装使用了。

    ==========================

    转载处请注明:博客园偷饭猫willian12345@126.com

  • 相关阅读:
    微信小程序wx.chooseImage和wx.previewImage的综合使用(图片上传不限制最多张数)
    js数组与字符串之间的相互转换
    微信小程序wx.previewImage实用案例(交流QQ群:604788754)
    PHP:第一章——PHP中的魔术常量
    小程序模板嵌套以及相关遍历数据绑定
    6 大主流 Web 框架优缺点对比:15篇前端热文回看
    通俗地讲,Netty 能做什么?
    Netty
    为什么选择Netty
    linux下gsoap的初次使用 -- c风格加法实例
  • 原文地址:https://www.cnblogs.com/willian/p/3424941.html
Copyright © 2020-2023  润新知