前端性能优化的指标分析

分析指标的方式

指标

TTFB (Time to First Byte)

表示浏览器接收第一个字节的时间, 是一个衡量对资源的请求和响应的第一个字节开始和到达之间时间的指标。

TTFB 是下列请求节点的时间损耗汇总:

Redirect time 重定向时延

Service worker 启动时延(如果适用)

DNS 查询时延

建立连接和 TLS 所消耗时延

请求,直到响应的第一个字节到达为止的时延

减少连接建立和后端服务的时延将有助于降低 TTFB


*

FP (First Paint)

首次绘制: 标记浏览器渲染任何在视觉上不同于导航前屏幕内容之内容的时间点.
*

FCP (First Contentful Paint)

首次内容绘制: 标记浏览器渲染来自 DOM 第一位内容的时间点

Contentful 可以是如下类型:

  • <img> 元素
  • <svg> 中的 <image> 元素
  • <video> 元素(如果定义了封面图,会影响LCP)
  • url() 背景图的元素
  • 块级元素带有文本节点或者内联文本子元素

LCP (Largest Contentful Paint)

最大内容渲染: 代表可视区"内容"最大的可见元素开始出现在屏幕上的时间点。

如果一个页面的 LCP 值很高,那么用户可能需要等待很长时间才能看到页面的主要内容,这可能会导致用户的体验下降,甚至可能导致用户离开页面。

当页面在载入的过程中,Google 会去抓取页面可视范围中最大的元素,并会随时针对可视范围中的内容改变,直到页面完全载入(load)后,才会将页面中最大的元素订为LCP

以上图为例,绿色方块的区域是内容最大的元素,所以在这个例子中,LCP等于这个元素开始渲染的时间

LCP的 Contentful 可以是如下类型:

  • <img> 元素
  • <svg> 中的 <image> 元素
  • <video> 元素(如果定义了封面图,会影响LCP)
  • url() 背景图的元素
  • 块级元素带有文本节点或者内联文本子元素

LCP控制到不超过2.5秒

ps: LCP 绘制时间上报

由于Web页面都是分阶段加载的,所以最大元素可能随时会发生变化。

为了捕获这种变化,浏览器会派发一个类型是 largest-contentful-paintPerformanceEntry 对象,表示浏览器绘制第一帧的时候最大的元素。在后来的渲染帧中,如果最大元素发生变化,会再次派发一个 PerformanceEntry 对象。

举个例子,一个页面包含一个文本标题和一张图片,首帧渲染的时候,文本是最大元素,随着图片加载完成,图片或成为最大元素。

只有元素已经渲染,而且对用户可见,这个元素才可以被当成最大元素。未加载的图片未被渲染,所以不会被考虑在内。如果用了自定义字体的文本,在字体文件加载之前,也不会被当成最大元素。

后来被JS添加到dom树上的节点,如果尺寸大于之前的最大元素,浏览器也会派发一个 PerformanceEntry 对象。

如果元素被移除,这个元素不会被当成最大元素。如果图片元素的src属性更改了,在新图片加载之前,这个元素也不会被当成最大元素。

如果用户产生了交互行为(如点击、滚动、按键等),浏览器会停止上报新的entry,因为用户的交互行为可能会导致页面元素的可见性变化。

对统计而言,你只需要统计最近上报的一次 PerformanceEntry 即可。

需要注意的是,如果用户打开页面之后,切换到后台,等再次回到前台的时候,用户产生了交互行为,该埋点就不准确了,会比真实的时间延长一些。

TBT (Total Blocking Time)

总阻塞时间 该指标测量First Contentful Paint 首次内容绘制 (FCP)与Time to Interactive 可交互时间 (TTI)之间的总时间
*

DCL 表示DomContentloaded事件触发的时间。

L 表示onLoad事件触发的时间。

DomContentloaded事件与onLoad事件的区别是,

浏览器解析HTML这个操作完成后立刻触发DomContentloaded事件,

而只有页面所有资源都加载完毕后(比如图片,CSS),才会触发onLoad事件。

相关推荐
奋斗的小羊羊6 小时前
HTML5关键知识点之多种视频编码工具的使用方法
前端·音视频·html5
前端呆猿6 小时前
深入解析HTML5中的object-fit属性
前端·css·html5
再学一点就睡6 小时前
实现大文件上传全流程详解(补偿版本)
前端·javascript·面试
你的人类朋友7 小时前
【Node&Vue】什么是ECMAScript?
前端·javascript·后端
路灯下的光8 小时前
用scss设计一下系统主题有什么方案吗
前端·css·scss
l_tian_tian_8 小时前
SpringClound——网关、服务保护和分布式事务
linux·服务器·前端
一只小风华~8 小时前
CSS @media 媒体查询
前端·css·媒体
shix .9 小时前
最近 | 黄淮教务 | 小工具合集
前端·javascript
John_ToDebug9 小时前
Chrome 内置扩展 vs WebUI:浏览器内核开发中的选择与实践
前端·c++·chrome
烛阴9 小时前
解锁动态键:TypeScript 索引签名完全指南
前端·javascript·typescript