移除未使用的 JavaScript

未使用的 JavaScript 可能會拖慢網頁載入速度:

  • 如果 JavaScript 具有轉譯封鎖功能,瀏覽器必須先下載、剖析、編譯及評估指令碼,才能處理轉譯網頁所需的所有其他作業。
  • 即使 JavaScript 為非同步 (而非禁止轉譯),程式碼也會在下載時與其他資源競爭頻寬,這可能會對效能產生重大影響。對於沒有無限數據方案的行動裝置使用者,透過網路傳送未使用的程式碼也會感到十分浪費。

未使用的 JavaScript 稽核失敗原因

Lighthouse 會標記每個內含超過 20 KB 的未使用程式碼的每個 JavaScript 檔案:

稽核的螢幕截圖。
按一下「網址」欄中的值,即可在新分頁中開啟指令碼的原始碼。

如何移除未使用的 JavaScript

偵測未使用的 JavaScript

Chrome 開發人員工具的「涵蓋率」分頁可逐行列出未使用的程式碼。

Puppeteer 中的 Coverage 類別可協助您自動偵測未使用程式碼及擷取所用程式碼的程序。

建立支援移除未使用的程式碼的工具

請查看以下 Tooling.Report 測試,瞭解 Bundler 是否支援有助於避免或移除未使用的程式碼:

堆疊專屬指南

Angular

如果您使用 Angular CLI,請在正式版本中加入來源對應,以檢查套件

Drupal

建議您移除未使用的 JavaScript 素材資源,並僅將必要的 Drupal 程式庫附加至相關頁面或頁面上的元件。詳情請參閱「定義程式庫」。

Joomla

考慮在網頁上載入未使用的 JavaScript 的 Joomla 擴充功能數量,或改用其他擴充功能。

Magento

停用 Magento 的內建 JavaScript 組合功能

回應

如果你不是在伺服器端轉譯,請使用 React.lazy() 分割 JavaScript 套件。否則,請使用 loadable-components 等第三方程式庫分割程式碼。

Vue (Vue)

如果你不是在伺服器端轉譯,且使用 Vue 路由器,請根據延遲載入路徑分割套件。

WordPress

有些 WordPress 外掛程式會在網頁中載入未使用的 JavaScript,建議你減少這類外掛程式的數量,或改用其他外掛程式。

資源