Web Vitals:提升用户体验的关键指标
Web Vitals 是 Google 提出的一套核心网页性能指标,旨在帮助开发者理解和优化网站的用户体验。这些指标分为核心 Web Vitals 和附加 Web Vitals,涵盖了加载性能、交互性和视觉稳定性三个方面。以下是详细的介绍和如何使用 Web Vitals 来优化你的网站。
核心 Web Vitals
-
核心 Web Vitals 包括三个关键指标:最大内容绘制(Largest Contentful Paint,简称 LCP)、首次输入延迟(First Input Delay,简称 FID)和累积布局偏移(Cumulative Layout Shift,简称 CLS)。
-
LCP(最大内容绘制):衡量页面主要内容元素渲染完成的时间。目标值应小于 2.5 秒。
-
FID(首次输入延迟):衡量用户第一次与页面交互(例如点击按钮)到浏览器开始处理该交互的时间。目标值应小于 100 毫秒。
-
CLS(累积布局偏移):衡量页面在加载过程中意外布局变化的程度。目标值应小于 0.1。
附加 Web Vitals
除了核心 Web Vitals,还有几个附加指标,包括首次内容绘制(First Contentful Paint,简称 FCP)和时间至首字节(Time to First Byte,简称 TTFB)。
-
FCP(首次内容绘制):衡量页面上的第一个文本或图像内容渲染完成的时间。目标值应小于 1.8 秒。
-
TTFB(时间至首字节):衡量从请求开始到接收到第一个字节的响应时间。目标值应小于 100 毫秒。
如何测量 Web Vitals
Web Vitals 可以通过实验室数据(Lab Data)和现场数据(Field Data)两种方式进行测量。
-
实验室数据:使用 Chrome DevTools 或 Lighthouse 等工具在受控环境中模拟真实用户的行为。
-
现场数据:通过实际用户在真实世界中的使用情况收集数据,通常需要在网站上实施 Web Vitals API。
如何优化 Web Vitals
下面是一些优化 Web Vitals 的通用策略:
优化 LCP:
- 压缩和优化关键资源,如图片和字体。
- 使用懒加载(Lazy Loading)技术,仅在需要时加载非关键资源。
- 避免在关键路径上使用大型 CSS 和 JavaScript 文件。
优化 FID:
- 减少主线程工作,避免长时间的 JavaScript 执行。
- 使用预加载(Preloading)和预取(Prefetching)技术。
- 使用服务工作者(Service Worker)缓存静态资源。
优化 CLS:
- 确保所有元素都有固定的尺寸,避免动态调整大小。
- 使用尺寸属性(如 width 和 height)来预留空间给图片和广告。
- 避免在页面加载过程中插入新的元素。
实施 Web Vitals
为了在你的网站上实施 Web Vitals 测量,你可以使用 Web Vitals 库。
// index.js
import { reportWebVitals } from 'web-vitals';reportWebVitals(console.log);
你也可以将数据上报到服务器或使用 Google Analytics 等工具进行分析。
使用 Lighthouse
Lighthouse 是一个开源的自动化工具,用于改进 Web 页面的质量。它可以生成一份报告,其中包含 Web Vitals 的分数以及优化建议。
// 安装 Lighthouse CLI
npm install -g lighthouse// 运行 Lighthouse
lighthouse https://example.com --chrome-flags="--headless"
进阶优化技巧
优化 LCP
使用预加载(Preloading):对于关键资源,如主样式表和关键 JavaScript 文件,使用 <link rel="preload">
标签进行预加载,确保它们在页面加载初期就能被浏览器获取。
<link rel="preload" href="/styles.css" as="style">
<link rel="preload" href="/main.js" as="script">
优化图片和媒体:压缩图片文件,使用现代图片格式(如 WebP),并为不同设备和网络条件提供多种分辨率的图片。
优化 FID
减少 JavaScript 执行时间:避免在关键路径上执行大型 JavaScript 文件,可以将它们放在文档末尾加载,或者使用异步加载方式。
<script src="/non-critical.js" defer></script>
使用 Web Workers:将一些复杂的计算任务放到 Web Workers 中执行,避免阻塞主线程。
优化 CLS
固定尺寸的媒体元素:确保所有的图片、视频和其他媒体元素都有明确的宽度和高度属性,避免在加载过程中引起布局重排。
<img src="/image.jpg" alt="An image" width="600" height="400">
使用 Resize Observer:动态调整元素大小时,使用 Resize Observer API 来代替定时器或 resize 事件,减少不必要的布局重排。
const observer = new ResizeObserver(entries => {entries.forEach(entry => {// 更新元素样式});
});
observer.observe(document.querySelector('#dynamic-element'));
监控和持续优化
实施 Web Vitals API:在你的网站上实施 Web Vitals API,收集真实用户的性能数据,以便持续监控和优化。
import { onCLS, onFCP, onFID, onLCP, onTTFB } from 'web-vitals';onLCP((lcp) => {// 发送 LCP 数据到服务器
});
onFID((fid) => {// 发送 FID 数据到服务器
});
onCLS((cls) => {// 发送 CLS 数据到服务器
});
使用 Google Search Console:Google Search Console 提供了 Core Web Vitals 报告,帮助你了解网站的性能表现,并提供具体的改进建议。
定期进行 Lighthouse 审计:将 Lighthouse 审计纳入你的开发流程,定期检查和优化 Web Vitals。
结合 SEO 和 UX
优化 Web Vitals 不仅可以提升用户体验,还能提高搜索引擎排名。Google 已经宣布,Web Vitals 成为了其排名算法的一部分,这意味着页面性能直接影响到网站的可见度和流量。因此,优化 Web Vitals 不仅是一项技术挑战,也是提升网站整体价值的战略决策。
结论
Web Vitals 提供了一套全面的性能指标,帮助开发者和网站所有者理解并优化用户体验。通过关注 LCP、FID 和 CLS 等关键指标,结合预加载、图片优化、Web Workers 和布局稳定性等技术手段,你可以显著提升网站的加载速度、交互性和稳定性。实施 Web Vitals API 和使用工具如 Lighthouse 和 Google Search Console 进行持续监控,将确保你的网站始终保持最佳状态,为用户提供卓越的体验。
相关文章:
Web Vitals:提升用户体验的关键指标
Web Vitals 是 Google 提出的一套核心网页性能指标,旨在帮助开发者理解和优化网站的用户体验。这些指标分为核心 Web Vitals 和附加 Web Vitals,涵盖了加载性能、交互性和视觉稳定性三个方面。以下是详细的介绍和如何使用 Web Vitals 来优化你的网站。 …...
c#中的约束、TimeSpan、defult、operator
c#中的约束 在C#中,约束(Constraints)用于限制泛型类型参数的类型,以确保泛型类型或方法在编译时能够满足特定的要求。约束允许开发者指定泛型类型参数必须满足的条件,比如实现特定的接口或继承自特定的类。以下是一些…...

挖矿木马攻破了服务器
最近被国外的挖矿木马攻破了服务器 根据非法登录,用 #last指令查看登录ip 首先删掉登录主机 #kill -9 pts/0 第二步 #top 看看什么占用cpu高 第三步杀死狂刷CPU的服务 过一分钟后,服务又开始狂刷cpu。 第四步根据pid查到服务地址 #systemctl status…...
从容应对技术面试:策略、技巧与成功案例
欢迎来到我的博客,很高兴能够在这里和您见面!欢迎订阅相关专栏: 工💗重💗hao💗:野老杂谈 ⭐️ 全网最全IT互联网公司面试宝典:收集整理全网各大IT互联网公司技术、项目、HR面试真题. ⭐️ AIGC时代的创新与未来:详细讲解AIGC的概念、核心技术、应用领域等内容。 ⭐…...
Spring Boot 整合 RestTemplate:详解与实战
Spring Boot 整合 RestTemplate:详解与实战指南 一、引言二、依赖添加Maven 示例:Gradle 示例: 三、创建 RestTemplate 实例四、使用 RestTemplate 发起请求五、处理响应六、高级用法1. 自定义 RestTemplate 实例2. 文件上传、下载以及常见的…...

【利用模板模式和责任链模式实现数据校验】
利用模板模式和责任链模式实现数据校验 一、业务背景二、模板模式和责任链模式代码实现1、数据校验抽象处理器ValidateHandler2、数据校验责任链工具类ValidateChainUtil3、网元调整数据校验抽象类AbstractNodeCheckHandler4、依次定义3个责任链handler,通过Order注…...
学习笔记第十九天
1.标准I/O的基本概念 标准输入(stdin):默认是指键盘输入。 标准输出(stdout):默认是指显示器输出。 标准错误(stderr):用于输出错误信息,也是指向显示器&…...
设计模式 - 单例模式
💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快! 文章目录 引言一、单例模…...

fastapi之WebSockets
文章目录 WebSockets基本概念FastAPI 中的 WebSocket 支持WebSocket 应用示例示例 1: 简单的 WebSocket 连接解释 示例 2: 广播消息的 WebSocket 实现解释 客户端代码示例 完整示例项目结构服务器端代码 (main.py)解释 简单的前端客户端 (static/index.html)解释 测试 相关代码…...
Kotlin 和 Java区别
Kotlin 和 Java 是两种主要用于 Android 开发的编程语言,它们之间有一些关键的区别: 1. 语法简洁性: Kotlin:具有更简洁的语法,减少了冗余代码。例如,Kotlin 支持类型推断,避免了大量的样板…...

windows 达梦到ORACLE dblink
达梦通过DBLINK访问Oracle数据库有两种: 方式一:通过Oracle oci接口; 方式二:一种是通过ODBC数据源的方式。 本案例选择使用Oralce OCI的方式去访问Oracle数据库。 配置Oracle OCI客户端 下载地址:https://www.oracle.com/database/techno…...
大数据应用组件
1、数据存储1.1、hive->hdfs、mapredus1.2、ClickHouse1.3、Elasticsearch1.4、PostgreSQL1.5、HBase 2、数据抽取2.1、Kettle2.2、DataX2.3、Canal2.4、Flink CDC2.5、Sqoop2.6、Filebeat&Logstash(日志) 3、任务编排3.1、Apache DolphinScheduler 4、数据处理4.1、spa…...

Docker Remote API未授权访问漏洞
9.Docker Remote API未授权访问漏洞 步骤一:使用以下Fofa语句对Docker产品进行搜索. port"2375" 步骤二:直接使用浏览器访问以下路径 /version#查看版本信息 /info#查看容器信息 漏洞修复 1.端口访问控制 对2375端口做网络访问控制,如设置iptables…...

算法训练.
一.扩散 题解: 计算点之间的距离,然后对图进行处理即可,这个数据规模较小,因此我使用了floyd,还有最小生成树和二份答案加并查集的写法; 代码: #include <iostream> #include <cstring> #in…...

08、MySQL-事务
目录 1、事务简介 2、事务操作 2.1 方式一 2.2 方式二 3、事务四大特性 4、并发事务问题 5、事务隔离级别 1、事务简介 事务是一组操作的集合,它是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,…...

2024 年的 Node.js 生态系统
数据来源于 Node.js Toolbox,网站展示了 Node.js 生态系统中积极维护且流行的库。...

LVS(Linux Virtual Server)
简介 LVS(Linux Virtual Server)是一个高性能的开源负载均衡解决方案,它通过在Linux内核中实现IPVS(IP Virtual Server)模块来提供负载均衡功能。LVS能够将外部请求根据特定的算法分发到后端的多个服务器上,…...
回顾Python
一、python基础 1、环境python2、python3 [rootpython ~]# yum list installed | grep python #检查是否有python包 [rootpython ~]# yum list installed | grep epel #检查是否有epel包 [rootpython ~]# yum -y install epel-release [rootpython ~]# yum -y install …...

【数据结构】队列,你必须知道的内部原理!!!
🌞🌞🌞生活本就沉闷,但跑起来就会有风 ~~~ 前言: 🌟🌟Hello家人们,这期讲解数据结构队列的基础知识,希望你能帮到屏幕前的你。 📚️上期博客在这里࿱…...

Ubuntu24.04编译FFmpeg6.1(支持x264、x265、fdk-acc)
FFmpeg是一个开源的多媒体处理工具集,可以用于处理音频、视频和图片等多种媒体格式。由于其强大的功能和灵活性,FFmpeg被广泛应用在多媒体处理领域,包括音视频编解码、流媒体服务器、视频转码等。FFmpeg7.0 版本移除了 6.0 之前已弃用的 API&…...

【入坑系列】TiDB 强制索引在不同库下不生效问题
文章目录 背景SQL 优化情况线上SQL运行情况分析怀疑1:执行计划绑定问题?尝试:SHOW WARNINGS 查看警告探索 TiDB 的 USE_INDEX 写法Hint 不生效问题排查解决参考背景 项目中使用 TiDB 数据库,并对 SQL 进行优化了,添加了强制索引。 UAT 环境已经生效,但 PROD 环境强制索…...

vscode(仍待补充)
写于2025 6.9 主包将加入vscode这个更权威的圈子 vscode的基本使用 侧边栏 vscode还能连接ssh? debug时使用的launch文件 1.task.json {"tasks": [{"type": "cppbuild","label": "C/C: gcc.exe 生成活动文件"…...
Qt Widget类解析与代码注释
#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码,写上注释 当然可以!这段代码是 Qt …...

Cloudflare 从 Nginx 到 Pingora:性能、效率与安全的全面升级
在互联网的快速发展中,高性能、高效率和高安全性的网络服务成为了各大互联网基础设施提供商的核心追求。Cloudflare 作为全球领先的互联网安全和基础设施公司,近期做出了一个重大技术决策:弃用长期使用的 Nginx,转而采用其内部开发…...
Python如何给视频添加音频和字幕
在Python中,给视频添加音频和字幕可以使用电影文件处理库MoviePy和字幕处理库Subtitles。下面将详细介绍如何使用这些库来实现视频的音频和字幕添加,包括必要的代码示例和详细解释。 环境准备 在开始之前,需要安装以下Python库:…...

vue3+vite项目中使用.env文件环境变量方法
vue3vite项目中使用.env文件环境变量方法 .env文件作用命名规则常用的配置项示例使用方法注意事项在vite.config.js文件中读取环境变量方法 .env文件作用 .env 文件用于定义环境变量,这些变量可以在项目中通过 import.meta.env 进行访问。Vite 会自动加载这些环境变…...
2023赣州旅游投资集团
单选题 1.“不登高山,不知天之高也;不临深溪,不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...

接口自动化测试:HttpRunner基础
相关文档 HttpRunner V3.x中文文档 HttpRunner 用户指南 使用HttpRunner 3.x实现接口自动化测试 HttpRunner介绍 HttpRunner 是一个开源的 API 测试工具,支持 HTTP(S)/HTTP2/WebSocket/RPC 等网络协议,涵盖接口测试、性能测试、数字体验监测等测试类型…...
django blank 与 null的区别
1.blank blank控制表单验证时是否允许字段为空 2.null null控制数据库层面是否为空 但是,要注意以下几点: Django的表单验证与null无关:null参数控制的是数据库层面字段是否可以为NULL,而blank参数控制的是Django表单验证时字…...
TJCTF 2025
还以为是天津的。这个比较容易,虽然绕了点弯,可还是把CP AK了,不过我会的别人也会,还是没啥名次。记录一下吧。 Crypto bacon-bits with open(flag.txt) as f: flag f.read().strip() with open(text.txt) as t: text t.read…...