国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 web前端 js教程 文字壓縮和程式碼分割和現(xiàn)代圖像格式 - 效能優(yōu)化

文字壓縮和程式碼分割和現(xiàn)代圖像格式 - 效能優(yōu)化

Dec 13, 2024 am 12:10 AM

Text compression & Code splitting & Modern image formats - Performance optimization

我嘗試了以下方法來優(yōu)化我的業(yè)餘專案效能:

  1. 文字壓縮
  2. 程式碼分割
  3. 現(xiàn)代影像格式.

分析器

我建立的應(yīng)用程式使用了 Vite 和 pnpm?,F(xiàn)代 Web 建置工具在建置過程中預(yù)設(shè)自動(dòng)最佳化 Web 效能。所以我們可以 pnpm run build 然後 pnpm dlxserve dist。然後使用 Chrome DevTools 的 Lighthouse 作為指南來解決它列出的每個(gè)瓶頸。

啟用文字壓縮

它影響FCPLCP。

Lighthouse 建議的第一件事是使用 brgzip 等演算法壓縮文字。

常見的做法是在發(fā)出網(wǎng)路請(qǐng)求時(shí)加入 Accept-Encoding: gzip。由於我正在建立的應(yīng)用程式在本地提供資源,因此我安裝了 vite-plugin-compress 來壓縮檔案。

第 1 步:安裝 vite-plugin-compress
第2步:設(shè)定vite.config.js文件,新增插件和一些參數(shù)。正如 Google 開發(fā)人員建議的那樣,應(yīng)該盡可能使用 br(brotliCompress) 而不是 gzip。

例如

viteCompression({
      verbose: true,
      disable: false,
      algorithm: 'brotliCompress',
      ext: '.br',
    }),

第 3 步:執(zhí)行 pnpm run build 來壓縮

它成功壓縮了.js和.css檔。

日誌:

? [vite-plugin-compression]:algorithm=brotliCompress - 壓縮檔案成功。

Vite 預(yù)設(shè)會(huì)使用 .gzip 壓縮文件,但是 brotliCompress 可以做得更好,在建置過程中進(jìn)行壓縮:

使用 gzip 進(jìn)行影片

vite v5.4.10 建置用於生產(chǎn)...
? 改造了 654 個(gè)模組。

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 kB

Vite-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

它影響FCPLCP。

使用 Google DevTools 中的「覆蓋率」標(biāo)籤查看未使用位元組超過 20kbs 的腳本。

由於我在 React 中使用 Vite,程式碼分割 是減少未使用的 JavaScript 的第一件事。

在 React 中,lazy() 可以幫助解決這個(gè)問題。

  1. 使用 包裹整個(gè) App 並提供後備 UI,如
    Loading
    ,這會(huì)在應(yīng)用程式載入時(shí)提供後備 UI。
  2. 使用lazy()包裝初始頁面未使用的組件。例如,對(duì)於遊戲,當(dāng)使用者按下 Esc 鍵時(shí),會(huì)彈出一個(gè)可以打包的選單。

以現(xiàn)代格式提供圖像

Chrome 開發(fā)者建議以 AVIFWebP 格式提供影像。我選擇 WebP 因?yàn)樗懈嗟目鐬g覽器支援。

最新版本的 Chrome、Firefox、Safari、Edge 和 Opera 支援 WebP,而 AVIF 支援較為有限。

您可以在我可以使用查看WebP圖像格式支援資訊。

您可以在WebP 上安裝cwebp 庫,並使用指令cwebp -q 50 images/flower1.jpg -o images/flower1.webp 將.png 轉(zhuǎn)換為.webpng 轉(zhuǎn)換為.webpng 。

此指令以 50 的品質(zhì)(0 是最差;100 是最好)轉(zhuǎn)換 images/flower1.jpg 檔案並將其另存為 images/flower1.webp。

壓縮結(jié)果相當(dāng)令人印象深刻。其中一個(gè)檔案的大小從 3.5 MB 減少到 178kb。即使是低資訊強(qiáng)度的也能提供 4 倍壓縮。

我們甚至可以寫一個(gè)簡單的 .bat 腳本,自動(dòng)將目標(biāo)資料夾下的所有 .png 圖片轉(zhuǎn)換為 .webp 圖片。

viteCompression({
      verbose: true,
      disable: false,
      algorithm: 'brotliCompress',
      ext: '.br',
    }),

參考

  • 刪除未使用的 JavaScript
  • 使用「覆蓋範(fàn)圍」標(biāo)籤查看已使用和未使用的 CSS。
  • 以現(xiàn)代格式提供影像。
  • 使用命令列建立 WebP 映像
  • 預(yù)編譯實(shí)用程式
  • WebP 影像格式 - 我可以使用
  • 最大內(nèi)容油漆 (LCP)
  • 首次內(nèi)容繪製 (FCP)

以上是文字壓縮和程式碼分割和現(xiàn)代圖像格式 - 效能優(yōu)化的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

Java vs. JavaScript:清除混亂 Java vs. JavaScript:清除混亂 Jun 20, 2025 am 12:27 AM

Java和JavaScript是不同的編程語言,各自適用於不同的應(yīng)用場(chǎng)景。 Java用於大型企業(yè)和移動(dòng)應(yīng)用開發(fā),而JavaScript主要用於網(wǎng)頁開發(fā)。

掌握J(rèn)avaScript評(píng)論:綜合指南 掌握J(rèn)avaScript評(píng)論:綜合指南 Jun 14, 2025 am 12:11 AM

評(píng)論arecrucialinjavascriptformaintainingclarityclarityandfosteringCollaboration.1)heelpindebugging,登機(jī),andOnderStandingCodeeVolution.2)使用林格forquickexexplanations andmentmentsmmentsmmentsmments andmmentsfordeffordEffordEffordEffordEffordEffordEffordEffordEddeScriptions.3)bestcractices.3)bestcracticesincracticesinclud

JavaScript評(píng)論:簡短說明 JavaScript評(píng)論:簡短說明 Jun 19, 2025 am 12:40 AM

JavascriptconcommentsenceenceEncorenceEnterential gransimenting,reading and guidingCodeeXecution.1)單inecommentsareusedforquickexplanations.2)多l(xiāng)inecommentsexplaincomplexlogicorprovideDocumentation.3)

如何在JS中與日期和時(shí)間合作? 如何在JS中與日期和時(shí)間合作? Jul 01, 2025 am 01:27 AM

JavaScript中的日期和時(shí)間處理需注意以下幾點(diǎn):1.創(chuàng)建Date對(duì)像有多種方式,推薦使用ISO格式字符串以保證兼容性;2.獲取和設(shè)置時(shí)間信息可用get和set方法,注意月份從0開始;3.手動(dòng)格式化日期需拼接字符串,也可使用第三方庫;4.處理時(shí)區(qū)問題建議使用支持時(shí)區(qū)的庫,如Luxon。掌握這些要點(diǎn)能有效避免常見錯(cuò)誤。

JavaScript與Java:開發(fā)人員的全面比較 JavaScript與Java:開發(fā)人員的全面比較 Jun 20, 2025 am 12:21 AM

JavaScriptIspreferredforredforwebdevelverment,而Javaisbetterforlarge-ScalebackendsystystemsandSandAndRoidApps.1)JavascriptexcelcelsincreatingInteractiveWebexperienceswebexperienceswithitswithitsdynamicnnamicnnamicnnamicnnamicnemicnemicnemicnemicnemicnemicnemicnemicnddommanipulation.2)

為什麼要將標(biāo)籤放在的底部? 為什麼要將標(biāo)籤放在的底部? Jul 02, 2025 am 01:22 AM

PlacingtagsatthebottomofablogpostorwebpageservespracticalpurposesforSEO,userexperience,anddesign.1.IthelpswithSEObyallowingsearchenginestoaccesskeyword-relevanttagswithoutclutteringthemaincontent.2.Itimprovesuserexperiencebykeepingthefocusonthearticl

JavaScript:探索用於高效編碼的數(shù)據(jù)類型 JavaScript:探索用於高效編碼的數(shù)據(jù)類型 Jun 20, 2025 am 12:46 AM

javascripthassevenfundaMentalDatatypes:數(shù)字,弦,布爾值,未定義,null,object和symbol.1)numberSeadUble-eaduble-ecisionFormat,forwidevaluerangesbutbecautious.2)

Java和JavaScript有什麼區(qū)別? Java和JavaScript有什麼區(qū)別? Jun 17, 2025 am 09:17 AM

Java和JavaScript是不同的編程語言。 1.Java是靜態(tài)類型、編譯型語言,適用於企業(yè)應(yīng)用和大型系統(tǒng)。 2.JavaScript是動(dòng)態(tài)類型、解釋型語言,主要用於網(wǎng)頁交互和前端開發(fā)。

See all articles