”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 提升 Web 性能:前端开发人员指南

提升 Web 性能:前端开发人员指南

发布于2024-11-08
浏览:883

Boosting Web Performance: A Guide for Frontend Developers

大家好!自从我上次写博客以来已经有一段时间了,我承认,这让我有点难过。现实是,有太多东西需要学习,有时感觉永远没有足够的时间来深入了解所有内容。我在跟谁开玩笑呢?事实是,我最近拖延得很厉害。

但最近,我一直在探索网络性能——这对于任何前端开发人员来说都是一个至关重要的话题——我很高兴分享我所学到的东西。 性能优化是其中之一,如果做得正确,可以使用户体验您的网站或网络应用程序的方式发生巨大变化。它不仅可以改善用户体验,还可以提高搜索引擎优化,甚至可以影响转化率。

那么,让我们开始吧!

为什么 Web 性能很重要

在当今快节奏的世界中,用户期望网站能够快速加载并顺利交互。如果您的网站速度很慢,用户就会离开——就这么简单。研究表明,即使是几秒钟的延迟也会导致更高的跳出率和更低的参与度。作为前端开发人员,我们有责任确保我们的应用程序不仅看起来不错,而且在各种条件下都表现良好。

在衡量性能方面,Google 通常被认为是黄金标准。 Google 提供了一组称为 Core Web Vitals 的关键指标,可帮助开发人员跟踪和提高其网站的性能。让我们来分解一下:

按照大人的说法Google这些事情对性能很重要

  • FCP(首次内容绘制)
  • LCP(最大内容涂料)
  • CLS(累积布局偏移)
  • TTI(交互时间)
  • INP(与下一个绘画的交互)

让我们更仔细地探索它们

FCP(首次内容绘制)

测量内容: FCP 测量用户导航到您的页面后第一个内容(文本、图像等)出现在屏幕上所需的时间。这是一个关键指标,因为它向用户提供页面正在加载的反馈。 FCP越快,用户体验越好。

如何改进 FCP:

最小化渲染阻塞资源:减少或消除阻塞页面渲染的资源,例如同步 JavaScript 或 CSS。对关键资源使用

延迟非关键 JavaScript: 对非必要脚本使用 deferasync 属性,以确保它们不会阻止初始绘制。

*使用服务器端渲染 (SSR):* SSR 有助于更快地交付初始 HTML,特别是对于动态内容,以便用户可以更快地看到有意义的内容。

优化CSS交付:最小化CSS和内联关键CSS的大小,以便浏览器可以更快地渲染内容。

使用内容交付网络 (CDN): 从 CDN 提供静态资产以减少延迟并加快资源交付。

LCP(最大内容涂料)

测量内容: LCP 重点关注最大元素(通常是英雄图像、大文本块或视频)在视口中完全渲染所需的时间。这是感知加载速度的一个很好的指标,因为一旦加载了最大的内容,用户就会认为页面已准备好。旨在将 LCP 保持在 2.5 秒以下 以获得快速体验。

如何改进 LCP:

优化和压缩图像:使用WebP等现代图像格式,压缩图像,并确保使用srcset和sizes属性提供正确的图像尺寸。

延迟加载首屏图像:对不能立即可见的图像实施延迟加载,以优先加载首屏内容。

预加载重要资源:使用标签更快地加载重要资源,如字体、英雄图像或大型媒体文件。

最小化阻碍渲染的 CSS: 就像使用 FCP 一样,尽量减少使用可能阻碍渲染的大型 CSS 文件。

减少第三方脚本:第三方广告、分析或其他脚本可能会减慢 LCP 的速度。推迟或异步加载非必要的脚本。

CLS(累积布局偏移)

测量内容: CLS 测量页面的视觉稳定性。您是否曾经在阅读某些内容时,突然布局发生变化,导致您迷失了位置或点击了错误的按钮?这是一个糟糕的 CLS 分数。 CLS 跟踪加载过程中页面上有多少元素发生意外移动。低 CLS 对于流畅的用户体验至关重要,尤其是在移动设备上。

如何改进 CLS:

设置图像和视频的尺寸:始终在图像上包含宽度和高度属性,或使用 CSS 宽高比框在加载媒体元素之前为其保留空间。

避免在现有内容之上插入内容:除非绝对必要(例如广告),否则避免在现有内容之上动态添加内容。

使用字体加载策略:加载自定义字体时,使用font-display: swap;以避免字体加载引起的布局变化。

避免在没有空间的情况下注入新广告或弹出窗口:确保在布局空间中考虑动态加载的广告、横幅或弹出窗口,以避免意外的变化。

使用与图像相同空间的图像占位符或加载器

TTI(交互时间)

测量内容: TTI 测量页面完全交互所需的时间。这意味着所有按钮、输入和链接都可用,并且主线程可以自由响应用户输入。快速的 TTI 可确保用户可以快速与您的内容互动,而不会感觉网站缓慢或无响应。

如何提高 TTI:

减少 JavaScript 执行时间: 分解大型 JavaScript 包并仅加载第一次交互所需的必要脚本。在 React 中使用代码拆分(使用 React.lazy())或在 JavaScript 中使用动态导入。
使用 Web Workers: 将繁重的非 UI 阻塞任务卸载给 Web Workers,以保持主线程响应。
延迟长任务: 将长 JavaScript 任务拆分为较小的任务,以避免阻塞主线程太长时间。
预加载关键资源: 确保预加载交互所需的基本资源(脚本、样式),以避免 TTI 延迟。
优化 CSS 和 JavaScript: 缩小、压缩基本代码并确定其优先级。使用树摇动来消除死代码并确保更快的脚本执行。使用GZIP或BROTLI压缩机制

INP(与下一个绘画的交互)

测量内容: INP 是一个相对较新的指标,它跟踪页面响应用户交互(如单击按钮、滚动或键入)并相应更新 UI 所需的时间。它有助于衡量初始负载之外的整体交互性,确保您的应用程序在整个用户会话期间保持敏捷。

如何提高INP:

减少输入延迟: 通过避免阻塞主线程的长 JavaScript 任务,确保快速处理用户输入(点击、按键)。

优先考虑输入响应性:使用 requestAnimationFrame 或 requestIdleCallback 在空闲时间处理非紧急工作,让主线程保持开放状态以进行交互处理。

使用去抖动和限制:处理频繁的用户交互(如滚动或打字)时,对事件处理程序进行去抖动或限制以防止 UI 变得无响应。

延迟加载非关键代码: 将非关键功能的加载推迟到初始交互之后。
例如,您可以使用 React.lazy() 和 Suspense 在 React 中延迟加载组件。

通过遵循这些策略,您可以显着改进这些关键指标并提供更快、响应更灵敏的用户体验。这些优化(尤其是一起应用时)有助于确保您的网站不仅通过 Google 的 Core Web Vitals 测试,而且为您的用户提供卓越的体验

我希望您发现此博客有用,并且您能够从中获得一些关键见解,以帮助您制定下一个绩效改进策略。

有关性能、网络安全、React、Angular、Vue 的更多精彩博客请继续关注我

版本声明 本文转载于:https://dev.to/__junaidshah/boosting-web-performance-a-guide-for-frontend-developers-fhk?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • Python 中的列表理解语法何时需要三元运算符?
    Python 中的列表理解语法何时需要三元运算符?
    列表理解难题:可迭代对象中的条件过滤在 Python 中,列表理解提供了一种基于现有可迭代对象创建列表的简洁方法。然而,出现了一个关于涉及 if 语句的列表理解的问题。目标是比较两个可迭代对象 a 和 b,并仅打印两者中出现的元素。预期的代码如下所示:print([y if y not in b f...
    编程 发布于2024-11-08
  • 使用 MetaTrader 订单管理和市场数据收集进行自动交易
    使用 MetaTrader 订单管理和市场数据收集进行自动交易
    Your AsimovMT class provides a comprehensive interface for interacting with MetaTrader5 (MT5) using Python. However, there are several areas in your c...
    编程 发布于2024-11-08
  • Python 列表的最大大小是多少以及它如何影响功能?
    Python 列表的最大大小是多少以及它如何影响功能?
    Python列表的最大大小:综合分析在Python中,列表是基本的数据结构,可以容纳多个不同类型的元素。它们的多功能性和灵活性使得了解它们的局限性至关重要,特别是在处理大型数据集时。本文探讨了 Python 列表可以达到的最大大小及其对其功能的影响。最大列表大小Python 列表的最大大小已定义通过...
    编程 发布于2024-11-08
  • 托管平台列表:综合指南
    托管平台列表:综合指南
    在数字时代,可靠的托管平台对于任何在线展示都至关重要,无论是个人博客、电子商务网站还是公司网站。有无数的选项可供选择,选择合适的托管平台可能会令人畏惧。本指南将帮助您浏览当今一些最好的托管平台,比较它们的功能、价格和对不同需求的适用性。 1. 蓝色主机 概述:Bluehost 是最受...
    编程 发布于2024-11-08
  • 在浏览器中将视频压缩为 webm
    在浏览器中将视频压缩为 webm
    ?增强您的网络视频:使用 React 将 MP4 压缩为 WebM 工作中没有任何有趣的事情感到无聊吗?好吧,就在那时我决定抓紧时间修补浏览器 API 的当前状态。我们可以直接通过 Web API 压缩视频吗?在这篇博客中,我将向您展示如何使用现代浏览器功能将 MP4 视频压缩为 ...
    编程 发布于2024-11-08
  • 现代 PHP 中的 PHP Fiber 并发性
    现代 PHP 中的 PHP Fiber 并发性
    PHP Fibers 在 PHP 8.1 中引入,带来了一种令人兴奋的新方法来处理 PHP 中的并发和异步编程。纤维允许您在执行过程中暂停和恢复函数,使开发人员能够更好地控制非阻塞操作,例如处理 I/O、数据库查询或 HTTP 请求,而无需停止整个脚本。 在本博客中,我们将探讨 PHP 纤维、它们的...
    编程 发布于2024-11-08
  • Laravel 的新时代:Accel 的百万美元 A 轮融资——这就是为什么它改变了游戏规则!
    Laravel 的新时代:Accel 的百万美元 A 轮融资——这就是为什么它改变了游戏规则!
    各位,请戴好帽子! Laravel 刚刚发布了一些激动人心的消息,震惊了开发界——由 Accel 领投的 A 轮融资 5700 万美元。作为一名热情的 Laravel 用户和企业家同事,这一公告在整个 PHP 社区引起了震动,我感到非常兴奋!那么,让我们来分析一下为什么这项投资意义重大,以及为什么 ...
    编程 发布于2024-11-08
  • C++11 的 `string::c_str()` 仍然以 Null 终止吗?
    C++11 的 `string::c_str()` 仍然以 Null 终止吗?
    C 11 的 string::c_str() 是否消除空终止?在 C 11 中,string::c_str 不再保证产生一个以 null 结尾的字符串。原因:在 C 11 中, string::c_str 的定义与 string::data 相同,而 string::data 又被定义相当于 *(b...
    编程 发布于2024-11-08
  • 数据分析师清单
    数据分析师清单
    SQL 清单 Excel女士清单 Power BI 清单 Tableau 清单 Python 清单 关注此 WhatsApp 频道以获取更多资源
    编程 发布于2024-11-08
  • 如何在 Go 中将 YAML 字段动态解析为有限结构集?
    如何在 Go 中将 YAML 字段动态解析为有限结构集?
    在 Go 中将 YAML 字段动态解析为有限结构体集简介在 Go 中将 YAML 解析为结构体非常简单。但是,当 YAML 字段可以表示多个可能的结构时,任务就会变得更加复杂。本文探讨了使用 Go 的 YAML 包的动态方法。使用 YAML v2 进行动态解组对于 Yaml v2,可以使用以下方法:...
    编程 发布于2024-11-08
  • 如何在 Python 中执行指数和对数曲线拟合?
    如何在 Python 中执行指数和对数曲线拟合?
    曲线拟合:Python 中的指数和对数方法虽然 Python 中可以使用 polyfit() 轻松进行多项式曲线拟合,但本指南探讨了指数和对数曲线的方法拟合。对数拟合要拟合 y = A B log x 形式的直线,只需执行 y 对 log x 的多项式拟合。import numpy as np x ...
    编程 发布于2024-11-08
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-08
  • 如何实现ES6模块的条件导入?
    如何实现ES6模块的条件导入?
    ES6模块的条件导入在ES6中,'import'和'export'关键字只能出现在模块的顶层模块。这可以防止条件导入,这是许多应用程序中的常见要求。这个问题探讨了这个问题的解决方案。最初,用户尝试使用条件语句导入模块,但这导致了语法错误。然后,用户使用 System....
    编程 发布于2024-11-08
  • 我们应该在 C++ 函数原型中使用异常说明符吗?
    我们应该在 C++ 函数原型中使用异常说明符吗?
    C 中的异常:我们应该在函数原型中指定它们吗?在 C 中,异常说明符允许函数声明它们是否可以抛出异常。然而,由于对其有效性和后果的担忧,它们的使用受到了质疑。反对使用异常说明符的原因:执行不力: 编译器并不严格强制执行异常说明符,因此违反它们可能不会导致错误。这会破坏它们的可靠性。程序终止:违反异常...
    编程 发布于2024-11-08
  • Python 的 If 语句中何时使用 and 关键字进行逻辑连接?
    Python 的 If 语句中何时使用 and 关键字进行逻辑连接?
    Python If 语句中的逻辑 AND在 Python 中使用 if 语句时,必须使用正确的逻辑运算符来计算多个条件。逻辑与运算符在许多编程语言中用 && 表示,它评估两个操作数的真实性,并且仅当两个操作数都为 true 时才返回 True。但是,在 Python 的 if 语句中,&& 不被识别...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3