」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 提升 Web 效能:前端開發人員指南

提升 Web 效能:前端開發人員指南

發佈於2024-11-08
瀏覽:710

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]刪除
最新教學 更多>
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSocke...
    程式設計 發佈於2025-01-01
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2025-01-01
  • HTML 格式標籤
    HTML 格式標籤
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    程式設計 發佈於2025-01-01
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2025-01-01
  • 如何使“preg_match”正規表示式不區分大小寫?
    如何使“preg_match”正規表示式不區分大小寫?
    使 preg_match 不區分大小寫在問題中提供的程式碼片段中,區分大小寫導致無法實現預期結果。要修正此問題,您可以在正規表示式中使用 i 修飾符,確保其不區分大小寫。 以下是修改程式碼的方法:preg_match("#(.{100}$keywords.{100})#i", s...
    程式設計 發佈於2025-01-01
  • 儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    解決PHP 中的POST 請求故障在提供的程式碼片段中:action=''而非:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"檢查$_POST陣列:表單提交後使用 var_dump 檢查 $_POST 陣列的內...
    程式設計 發佈於2025-01-01
  • DocumentFilter 如何有效地將 JTextField 輸入限制為整數?
    DocumentFilter 如何有效地將 JTextField 輸入限制為整數?
    將 JTextField 輸入過濾為整數:使用 DocumentFilter 的有效方法雖然直觀,但使用鍵偵聽器來驗證 JTextField 中的數字輸入是不夠的。相反,更全面的方法是使用 DocumentFilter。 DocumentFilter:強大的解決方案DocumentFilter 監視...
    程式設計 發佈於2025-01-01
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1和$array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建構一...
    程式設計 發佈於2025-01-01
  • 插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入記錄時如何解決「一般錯誤:2006 MySQL 伺服器已消失」介紹:將資料插入MySQL 資料庫有時會導致錯誤「一般錯誤:2006 MySQL 伺服器已消失」。當與伺服器的連線遺失時會出現此錯誤,通常是由於 MySQL 配置中的兩個變數之一所致。 解決方案:解決此錯誤的關鍵是調整wait_tim...
    程式設計 發佈於2025-01-01
  • 如何從 Go 程式設定 `ulimit -n`?
    如何從 Go 程式設定 `ulimit -n`?
    如何在golang程式中設定ulimit -n? Go的syscall.Setrlimit函式允許在Go程式中設定ulimit -n。這允許在程式內自訂資源限制,而無需進行全域變更。 瞭解 setrlimitsetrlimit 系統呼叫設定目前程序的資源限制。它需要兩個參數:資源限制類型 (RLIM...
    程式設計 發佈於2024-12-31
  • 為什麼 Java 列印陣列的方式很奇怪,如何正確列印陣列的內容?
    為什麼 Java 列印陣列的方式很奇怪,如何正確列印陣列的內容?
    Java 中奇怪的數組打印在 Java 中,數組不僅僅是值的集合。它們是具有特定行為和表示的物件。當您使用 System.out.println(arr) 列印陣列時,您實際上是在列印物件本身,而不是其內容。 此預設表示顯示陣列的類別名,後面接著該物件的十六進位雜湊程式碼目的。因此,例如,整數數組可...
    程式設計 發佈於2024-12-31
  • 使用 Lithe 進行 PHP 會話管理:從基本設定到進階使用
    使用 Lithe 進行 PHP 會話管理:從基本設定到進階使用
    當我們談論 Web 應用程式時,首要需求之一是在使用者瀏覽頁面時維護使用者資訊。這就是 Lithe 中的 會話管理 的用武之地,它允許您儲存登入資訊或使用者首選項等資料。 安裝簡單快速 要開始在 Lithe 中使用會話,您只需透過 Composer 來安裝會話中間件。只需在專案的...
    程式設計 發佈於2024-12-31
  • 如何在 Java 中優化建構 SQL 字串以進行資料庫操作?
    如何在 Java 中優化建構 SQL 字串以進行資料庫操作?
    Java 中SQL 字串建構的最佳方法作業資料庫(更新、刪除、插入、選擇)通常涉及建置SQL 字符串。具有大量“”運算符和引號的標準字串連接可能會導致可讀性挑戰。幸運的是,有更有效的方法來解決這個問題。 準備好的語句和查詢參數建議的方法是使用帶有查詢參數的準備好的語句,因為它可以增強安全性和效能。這...
    程式設計 發佈於2024-12-31
  • 閉包 - JavaScript 挑戰
    閉包 - JavaScript 挑戰
    您可以在 repo Github 上找到這篇文章中的所有程式碼。 關閉相關的挑戰 你好世界 /** * @return {Function} */ function createHelloWorld() { return function (...args)...
    程式設計 發佈於2024-12-31
  • 如何在 Python 中檢查 NaN(不是數字)?
    如何在 Python 中檢查 NaN(不是數字)?
    檢查 NaN(不是數字)在 Python 中,NaN(不是數字)由 float('nan') 表示。它用於表示無法表示為實數的值。若要檢查值是否為 NaN,請使用 math.isnan 函數。 範例:import math x = float('nan') if math.isnan...
    程式設計 發佈於2024-12-29

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3