zoukankan      html  css  js  c++  java
  • 首屏和白屏时间计算

    首先明确,首屏和白屏的时间计算,没有明确的API可以得到。

    白屏 = 开始显示body的时间 - 开始请求的时间

    首屏 = 首屏内容渲染结束的时间 - 开始请求的时间

    具体计算方法如下:

    1. 白屏

    支持performance api,开始请求的时间 performance.timing.navigationStart

    <html>
        <head>
            <title>白屏时间</title>
            <link href="xxxxx"/>
            <script>var endTime = new Date() </script>
        </head>    
        <body>    
        </body>
    </html>

    白屏 = endTime - performance.timing.navigationStart

    不支持performance api,只能采用打点的方式,在dom中插入 <script> startTime = Date.now(); </script>

    <html>
        <head>
            <script> var startTime = new Date() </script>       
            <title>白屏时间</title>
            <link href="xxxxx"/>
            <link href="xxxxx"/>
            <script> var endTime = new Date() </script>    
        </head>    
        <body></body>
    </html>

    白屏 = endTime - startTime

    2. 首屏

    首屏是指,在不滚动屏幕前提下,第一屏页面显示完成花费的时间。页面内容显示完成,才算首屏时间,部分未显示,不算。首屏时间一般在5秒内,算优秀,在10秒内可接受,超过10秒,无法忍受。

    首屏渲染结束这个时间,无法确切的计算。一般可以在几个近似的地方打点:

    1. 首屏dom和第二屏dom之间 打点 不同屏幕尺寸,有差异,模糊计算
    2. 首屏图片中最慢的加载完成 打点 监听所有首屏的图片,在onload事件中,记录时间最大值
    3. 在domReady或onload中 打点

  • 相关阅读:
    Accoridion折叠面板
    mui列表系列
    按照中文首字母排序查询表数据
    五分位算法
    springmvc添加拦截器
    springmvc添加定时任务
    通过后台解决跨域调用接口问题
    eclipse搭建ssm框架
    Java 将图片转成base64,传到前台展示
    用mysql存储过程代替递归查询
  • 原文地址:https://www.cnblogs.com/mengff/p/12930621.html
Copyright © 2011-2022 走看看