前端性能优化的指标分析

分析指标的方式

指标

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事件。

相关推荐
code_YuJun18 分钟前
corepack 作用
前端
千寻girling18 分钟前
Koa.js 教程 | 一份不可多得的 Node.js 的 Web 框架 Koa.js 教程
前端·后端·面试
全栈前端老曹20 分钟前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
code_YuJun20 分钟前
pnpm-workspace.yaml
前端
天才熊猫君23 分钟前
“破案”笔记:iframe动态加载内容后,打印功能为何失灵?
前端
五月君_40 分钟前
炸裂!Claude Opus 4.6 与 GPT-5.3 同日发布:前端人的“自动驾驶“时刻到了?
前端·gpt
Mr Xu_44 分钟前
前端开发中CSS代码的优化与复用:从公共样式提取到CSS变量的最佳实践
前端·css
鹏北海-RemHusband1 小时前
从零到一:基于 micro-app 的企业级微前端模板完整实现指南
前端·微服务·架构
LYFlied1 小时前
AI大时代下前端跨端解决方案的现状与演进路径
前端·人工智能
光影少年1 小时前
AI 前端 / 高级前端
前端·人工智能·状态模式