Core Web Vitals 分析与优化

83次阅读
没有评论

共计 3447 个字符,预计需要花费 9 分钟才能阅读完成。

本文是SEO 实战指南系列中的第 1/1 篇文章

Core Web Vitals(核心页面指标)是一种速度指标,用于衡量网站的用户体验,这个指标在 2021 年 5 月被纳入 Google 页面排名指标中。

简介#

Core Web Vitals 由三部分组成:

  1. Largest Contentful Paint (LCP): 最大内容绘制
  2. Interaction To Next Paint (INP): 到下一次绘制时的交互
  3. Cumulative Layout Shift (CLS): 累积布局偏移

由于 Core Web Vitals 的重要性,Google 提供了多种工具来测试和监控这些指标,如下是一些常用的工具:

  1. Google Search Console
  2. PageSpeed Insights
  3. Chrome DevTools

另外还有一些第三方的工具来分析 Core Web Vitals,如:

  1. GTmetrix

本站一般使用 PageSpeed Insights 和 Chrome DevTools 来分析网站的 Core Web Vitals,这也是大多数站长使用的工具。

LCP#

LCP 即渲染页面中单个最大的可见元素,用于衡量加载网页主要内容所需的时间。一般来说,最大元素通常是图片(<img><svg>url()的背景图等)或视频内容。

若 LCP 是图片的话,那么整个分析过程可分为四个阶段:

  1. TTFB
    即用户从开始初始化页面(例如点击链接)到接收到 HTML 文档的第一个字节的时间。
  2. Load delay
    即资源加载延迟,表示从 TTFB 到浏览器开始加载 LCP 资源之间的时间。如果 LCP 元素不需要加载资源即可呈现(如使用系统字体的文本节点),则此时间为 0。
  3. Load time
    即资源加载时长,表示加载 LCP 资源的时长。如果 LCP 元素不需要加载资源即可渲染,则此时间为 0。
  4. Render delay
    元素渲染延迟,表示从 LCP 资源完成加载到 LCP 元素完全渲染之间的时间。

Core Web Vitals 分析与优化

一般来说,资源加载延迟和元素渲染延迟这两者都和延迟有关,所以值应该尽可能的小。不过若网页的 LCP 时间始终在 2.5 秒内,那么这块内容也不用急着优化。

该指标值低于 2.5 秒表示良好,高于 4 秒表示差:
Core Web Vitals 分析与优化 理想的 LCP 值为 2.5 秒或更短

分析 LCP#

Chrome DevTools#

DevTools 提供了两种分析 Core Web Vitals 的方法:

  1. 打开 Chrome,按 F12 打开 DevTools,点击 Performance,点击右下角的 Record and reload
    Core Web Vitals 分析与优化
    重新加载完成后会得到本次加载耗时的分析报告,将鼠标移动到 Timings 这行上的 LCP 上,会在网页上显示对应的 LCP 元素:
    Core Web Vitals 分析与优化

  2. 或者按 F12 打开 DevTools 后,点击 Lighthouse,在分析报告中点击 LCP 即可看到 LCP 元素:
    Core Web Vitals 分析与优化

PageSpeed Insights#

在 PageSpeed Insights 中生成网站的报告后,点击 LCP 即可看到诊断信息问题:
Core Web Vitals 分析与优化

可以看到最大内容是图片,主要是花在 Load Delay。

优化 LCP#

根据 LCP 不同阶段的耗时可进行针对性的优化。

优化 TTFB#

一般来说,大多数网站都应力求将 TTFB 时间控制在 0.8 秒内。若该时间超出 1 秒,则需要考虑如何更快的响应请求,一般来说可以考虑如下方案:

  1. 使用 CDN
    CDN 通过使用分布式服务器网络,将资源缓存在距离用户较近的服务器(即“边缘服务器”)上;另外 CDN 提供商通常有更快的 DNS 解析时间,且可能对数据进行压缩优化。
  2. 增加缓存
    无论是页面缓存还是 Redis 等缓存,都能提升绝大多数网站的响应时间。对于使用 WordPress 的站点,可启用缓存插件来优化速度。
  3. 避免多次重定向
    若请求收到资源位于其他位置的响应时,会重新请求定向到新的位置,这个过程无疑会让响应时长翻倍。重定向有两种类型:

    1. 同源重定向
      重定向到同一网站的其他位置,如 http 请求自动重定向为 https 请求,或 URL 非 / 结尾的地址重定向 到 / 结尾的地址。这类重定向一般较容易解决,对于 http 重定向到 https 来说,可以在请求头中设置 Strict-Transport-Security 来强制访问 https 站点。
    2. 跨域重定向
      重定向到其他网站,如很多网址会通过短地址工具转化一下 URL 地址。

优化资源加载延迟#

从理论上讲,资源在 TTFB 后立即就可以加载了,但实际上浏览器真正开始加载资源之前总会有一些延迟,一般来说如下因素会影响 LCP 加载速度:

  1. 资源被发现的时间
    若元素的信息存在于初始 HTML 标记中而不是 JavaScript 动态生成的话,浏览器可以通过扫描 HTML 文档响应来快速发现 LCP 资源,如:

    • <img> 已设置了 srcsrcset 属性。
    • CSS 中的 background-image 通过 HTML 标记中的 <link rel="preload">(或使用 Link 标头)预加载。
    • 文本字体是在 HTML 标记中使用 <link rel="preload">(或使用 Link 标头)预加载。
      对于这种情况导致的延迟,应该尽量避免通过 JavaScript 更新元素信息。
  2. 资源加载的优先级
    若资源只能通过外部 CSS 或 JavaScript 文件的方式引用,那么可以提高优先级来预加载资源。如 <img> 通过 loading="lazy" 开启懒加载后,只有当图片位于视界内系统才会加载资源,因此加载时间可能会比正常情况下更晚一些。若我们认为 <img> 元素可能是网页的 LCP 元素,那么可以为其设置 fetchpriority="high" 属性来优先加载:<img fetchpriority="high" src="/path/to/image.webp" />,或者去掉 <img> 元素的 loading="lazy" 属性,让浏览器自动加载。

优化资源加载时长#

缩短加载时长即减少将资源的字节传输到用户设备所用的时间,一般来说有如下方法:

  1. 开启网站压缩。这是一种简单且十分有效的优化方法,具体操作见WordPress 网站开启 Gzip 压缩一文。
  2. 减少资源大小
    如下是一些文件的常用优化方法:

    • 图片:图片压缩;将 png/jpg 转为 WebP/AVIF;
    • CSS/JS 文件:去掉不必要的字符以生成最小( 一般名为 x.min.css.x.min.js )文件;
    • 字体文件:
      • 尽量使用系统默认字体;
      • 若想使用非系统默认字体,可将字体文件分发到 CDN 中;
      • 还可以在 CSS 中设置 font-display: optional;,表示只给一小段时间用于加载指定字体,若没加载成功,将使用默认字体渲染页面。
  3. 减少传输距离
    即使用 CDN 优化传输时间。

优化元素渲染延迟#

LCP 元素在完成加载后无法立即呈现的主要原因有如下几种:

  1. 依赖的 CSS 或 JavaScript 文件还在加载中:对于这种情况需要缩减、压缩这些依赖文件。
  2. 渲染主线程被其他长时间运行的任务阻塞:如下载某些和渲染元素不相关的 JavaScript 文件导致渲染延迟。

INP#

INP 在 2024 年 3 月代替 FID 成为 Core Web Vital 指标之一。

INP 测量了从用户开始与网页交互(如点击按钮或链接等)到浏览器完成该交互的时间。举例来说,当用户点击一个按钮时,INP 会记录从点击到按钮状态改变并重新绘制的时间。INP 包含以下三类交互:

  • 点击鼠标
  • 点击触控屏
  • 实体键盘或荧幕键盘上的按键

该指标值低于 200ms 表示良好,高于 500ms 表示差:
Core Web Vitals 分析与优化

优化 INP#

  1. 最小化或异常加载 JavaScript
  2. 使用 web worker:Web worker 是一种在后台运行 JavaScript 而不会阻塞主线程的简单方法。

CLS#

CLS 量化了网页中的内容布局变化,该指标用于衡量视觉稳定性。

该指标值低于 0.1 表示良好,高于 0.25 表示差:
Core Web Vitals 分析与优化

优化 CLS#

既然 CLS 表示而已偏移情况,那么尽量减少网页初始化完成后的布局变化就行了。以下是一些常用策略:

  1. 为图片、视频、广告等媒体元素指定 widthheight 属性,这会告诉浏览器媒体项目将占用多少空间,从而减少布局变化。
  2. 对于 JavaScript 动态生成的内容,可以提前使用占位元素(如 Bootstrap 中的 Placeholders 组件)临时展示,或设置该元素块的大小。

优化效果#

本站在使用上述各种优化方法,重新诊断的效果如下:
Core Web Vitals 分析与优化

参考#

本文参考了 Google 前端开发人员文档,如有兴趣可访问如下文章来更深入的了解 Core Web Vitals 相关内容:

  1. Largest Contentful Paint (LCP)
  2. Optimize Largest Contentful Paint
  3. Cumulative Layout Shift (CLS)
  4. Interaction to Next Paint (INP)

如果您对网站优化有兴趣,还可以参考优化 WordPress 网站速度

正文完
 0
管理员
版权声明:本站原创文章,由 管理员 于2024-11-02发表,共计3447字。
转载说明:除特殊说明外本站文章皆由 CC-4.0 协议发布,转载请注明出处。
评论(没有评论)