我嘗試了以下方法來優化我的業餘專案效能:
- 文字壓縮
- 程式碼分割
- 現代影像格式.
分析器
我建立的應用程式使用了 Vite 和 pnpm。現代 Web 建置工具在建置過程中預設自動最佳化 Web 效能。所以我們可以 pnpm run build 然後 pnpm dlxserve dist。然後使用 Chrome DevTools 的 Lighthouse 作為指南來解決它列出的每個瓶頸。
啟用文字壓縮
它影響FCP和LCP。
Lighthouse 建議的第一件事是使用 br 或 gzip 等演算法壓縮文字。
常見的做法是在發出網路請求時加入 Accept-Encoding: gzip。由於我正在建立的應用程式在本地提供資源,因此我安裝了 vite-plugin-compress 來壓縮檔案。
第 1 步:安裝 vite-plugin-compress
第2步:設定vite.config.js文件,新增插件和一些參數。正如 Google 開發人員建議的那樣,應該盡可能使用 br(brotliCompress) 而不是 gzip。
例如
viteCompression({ verbose: true, disable: false, algorithm: 'brotliCompress', ext: '.br', }),
第 3 步:執行 pnpm run build 來壓縮
它成功壓縮了.js和.css檔。
日誌:
✨ [vite-plugin-compression]:algorithm=brotliCompress - 壓縮檔案成功。
Vite 預設會使用 .gzip 壓縮文件,但是 brotliCompress 可以做得更好,在建置過程中進行壓縮:
使用 gzip 進行影片
vite v5.4.10 建置用於生產...
✓ 改造了 654 個模組。index-B9QUW17e.css 8.60 kB │ gzip: 2.33 kB
PauseMenu-DjZ95K-6.js 1.77 kB │ gzip: 0.62 kB
索引-ohAKp9W9.js 1,688.05 kB │ gzip: 454.20 kBVite-plugin-compression with br
✨ [vite-plugin-compression]:algorithm=brotliCompress - 壓縮檔案成功:
PauseMenu-DjZ95K-6.js.br 1.73kb / brotli壓縮:0.51kb
索引-B9QUW17e.css.br 8.40kb / brotli壓縮:1.97kb
索引-ohAKp9W9.js.br 1648.49kb / brotli壓縮:345.30kb
減少未使用的 JavaScript
它影響FCP和LCP。
使用 Google DevTools 中的「覆蓋率」標籤查看未使用位元組超過 20kbs 的腳本。
由於我在 React 中使用 Vite,程式碼分割 是減少未使用的 JavaScript 的第一件事。
在 React 中,
- 使用
包裹整個 App 並提供後備 UI,如 Loading,這會在應用程式載入時提供後備 UI。 - 使用lazy()包裝初始頁面未使用的組件。例如,對於遊戲,當使用者按下 Esc 鍵時,會彈出一個可以打包的選單。
以現代格式提供圖像
Chrome 開發者建議以 AVIF 或 WebP 格式提供影像。我選擇 WebP 因為它有更多的跨瀏覽器支援。
最新版本的 Chrome、Firefox、Safari、Edge 和 Opera 支援 WebP,而 AVIF 支援較為有限。
您可以在我可以使用查看WebP圖像格式支援資訊。
您可以在WebP 上安裝cwebp 庫,並使用指令cwebp -q 50 images/flower1.jpg -o images/flower1.webp 將.png 轉換為.webpng 轉換為.webpng 。
此指令以 50 的品質(0 是最差;100 是最好)轉換 images/flower1.jpg 檔案並將其另存為 images/flower1.webp。
壓縮結果相當令人印象深刻。其中一個檔案的大小從 3.5 MB 減少到 178kb。即使是低資訊強度的也能提供 4 倍壓縮。
我們甚至可以寫一個簡單的 .bat 腳本,自動將目標資料夾下的所有 .png 圖片轉換為 .webp 圖片。
viteCompression({ verbose: true, disable: false, algorithm: 'brotliCompress', ext: '.br', }),
參考
- 刪除未使用的 JavaScript
- 使用「覆蓋範圍」標籤查看已使用和未使用的 CSS。
- 以現代格式提供影像。
- 使用命令列建立 WebP 映像
- 預編譯實用程式
- WebP 影像格式 - 我可以使用
- 最大內容油漆 (LCP)
- 首次內容繪製 (FCP)
以上是文字壓縮和程式碼分割和現代圖像格式 - 效能優化的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

本教程向您展示瞭如何將自定義的Google搜索API集成到您的博客或網站中,提供了比標準WordPress主題搜索功能更精緻的搜索體驗。 令人驚訝的是簡單!您將能夠將搜索限制為Y

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

本文系列在2017年中期進行了最新信息和新示例。 在此JSON示例中,我們將研究如何使用JSON格式將簡單值存儲在文件中。 使用鍵值對符號,我們可以存儲任何類型的

利用輕鬆的網頁佈局:8 ESTISSEL插件jQuery大大簡化了網頁佈局。 本文重點介紹了簡化該過程的八個功能強大的JQuery插件,對於手動網站創建特別有用

核心要點 JavaScript 中的 this 通常指代“擁有”該方法的對象,但具體取決於函數的調用方式。 沒有當前對象時,this 指代全局對象。在 Web 瀏覽器中,它由 window 表示。 調用函數時,this 保持全局對象;但調用對象構造函數或其任何方法時,this 指代對象的實例。 可以使用 call()、apply() 和 bind() 等方法更改 this 的上下文。這些方法使用給定的 this 值和參數調用函數。 JavaScript 是一門優秀的編程語言。幾年前,這句話可

jQuery是一個很棒的JavaScript框架。但是,與任何圖書館一樣,有時有必要在引擎蓋下發現發生了什麼。也許是因為您正在追踪一個錯誤,或者只是對jQuery如何實現特定UI感到好奇

該帖子編寫了有用的作弊表,參考指南,快速食譜以及用於Android,BlackBerry和iPhone應用程序開發的代碼片段。 沒有開發人員應該沒有他們! 觸摸手勢參考指南(PDF)是Desig的寶貴資源


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 Linux新版
SublimeText3 Linux最新版

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

Atom編輯器mac版下載
最受歡迎的的開源編輯器

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)