网站首页 > 技术文章 正文
对悬浮窗进行分析
下面以一个表格的形式进行分析:
在0毫秒查询
在9.31毫秒开始
资源调度时间 | 颜色 | 时间 |
查询中 | 浅灰 | 9.31毫秒 |
连接开始 | 颜色 | 时间 |
停滞 | 深灰 | 4.14毫秒 |
代理转发 | 深灰 | 0.53毫秒 |
请求/响应 | 颜色 | 时间 |
请求发送 | 深灰 | 0.29毫秒 |
等待中 | 绿色 | 20.81毫秒 |
内容下载 | 蓝色 | 3.48毫秒 |
总时间:38.03毫秒
可以分为3部分,第1部分是客户端发送请求前的准备工作,包括资源调度,代理转发等等时间,此时是在为发送http请求做准备工作。
第2部分,也就是其中最重要的等待中时间,它代表的是从请求资源到第一个字节下载完成的时间,即获取在接收到响应的首字节前花费的毫秒数。
第3部分,表示传输时间(下载第一个和最后一个字节之间的时间)。
瀑布流中各项内容意义
排队: 出现下面的情况时,浏览器会把当前请求放入队列中进行排队
有更高优先级的请求时
和目标服务器已经建立了6个TCP链接(最多6个,适用于HTTP / 1.0和HTTP / 1.1)
浏览器正在硬盘缓存上简单的分配空间
停滞: 请求会因为上面的任一个原因而阻塞
DNS查询:浏览器正在解析IP地址,在浏览器和服务器进行通信之前,必须经过DNS查询,将域名转换成IP地址。在这个阶段,你可以处理的东西很少。但幸运的是,并非所有的请求都需要经过这一阶段
代理协商:浏览器正在与代理服务器协商请求
要求已发送:请求已发送
ServiceWorker准备:浏览器正在启动服务器
请求ServiceWorker:请求正在被发送到服务器
等待(TTFB):浏览器等待响应第一个字节到达的时间。包含来回的延迟时间和服务器准备响应的时间
内容下载:浏览器正在接收响应信息
接收推送:浏览器正在通过HTTP / 2服务器推送接收此响应的数据
阅读推。:浏览器正在读取以前接收到的本地数据
初始连接:在浏览器发送请求之前,必须建立TCP连接。这个过程仅仅发生在瀑布图中的开头几行,否则这就是个性能问题
SSL / TLS协商:如果你的页面是通过SSL / TLS这类安全协议加载资源,这段时间就是浏览器建立安全连接的过程。目前谷歌将HTTPS作为其搜索排名因素之一,SSL / TLS协商的使用变得越来越普遍了
时间到第一个字节(TTFB): TTFB是浏览器请求发送到服务器的时间+服务器处理请求时间+响应报文的第一字节到达浏览器的时间。我们用这个指标来判断你的网络服务器是否性能不够,或者说你是否需要使用CDN.「TTFB超过200ms,可以考虑对网络进行性能优化了」
下载:这是浏览器用来下载资源所用的时间。这段时间越长,说明资源越大。理想情况下,你可以通过控制资源的大小来控制这段时间的长度
紫色的线
紫线是开始通过脚本加载资源的一个临界线,紫线之前,都是通过HTML文件进行加载的资源,要么是链接的src,要么是脚本的src; 而紫线之后,就成了通过执行HTML文件加载进来的js script,进行加载资源的操作。
如何根据瀑布图进行性能优化
瀑布图提供了三个直观的东西来帮助我们进行前端性能优化
- 首先,减少所有资源的加载时间。亦即减小瀑布图产品的宽度。瀑布图越窄,网站的访问速度越快
- 其次,减少请求数量也就是降低瀑布图的高度。瀑布图越矮越好
- 最后,通过优化资源请求顺序来加快渲染时间。从图上看,就是将绿色的“开始渲染”线向左移。这条线向左移动得越远越好
参考链接:https://www.jianshu.com/p/c7e0dad634db
https://blog.csdn.net/carian_violet/article/details/84954360
猜你喜欢
- 2024-12-07 15种常用的在线工具网站清单「值得收藏」
- 2024-12-07 bootstrap5带图瀑布流实现代码解决图片加载bug
- 2024-12-07 图解 Promise 实现原理(二):Promise 链式调用
- 2024-12-07 10个实用的JS技巧「值得收藏」
- 2024-12-07 APP广告变现技术——广告分层(瀑布流)
- 2024-12-07 WebView 详细解说「图文」
- 2024-12-07 高频面试题:JavaScript事件循环机制解析
- 2024-12-07 lodash那些功能强大的API「JS篇」
你 发表评论:
欢迎- 07-07使用AI开发招聘网站(100天AI编程实验)
- 07-07Tailwindcss 入门(tailwindcss中文文档)
- 07-07CSS 单位指南(css计量单位)
- 07-07CSS 定位详解(css定位属性的运用)
- 07-07程序员可以作为终身职业吗?什么情况下程序员会开始考虑转行?
- 07-07云和学员有话说:国企转行前端开发,斩获13K高薪!
- 07-0791年转行前端开发,是不是不该转,有啥风险?
- 07-07计算机图形学:变换矩阵(图形学 矩阵变换)
- 595℃几个Oracle空值处理函数 oracle处理null值的函数
- 587℃Oracle分析函数之Lag和Lead()使用
- 575℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 572℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 568℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 561℃【数据统计分析】详解Oracle分组函数之CUBE
- 548℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 541℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端懒加载 (49)
- 前端获取当前时间 (50)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)