移除未使用的 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,建議你減少這類外掛程式的數量,或改用其他外掛程式。
資源
除非另有註明,否則本頁面中的內容是採用創用 CC 姓名標示 4.0 授權,程式碼範例則為阿帕契 2.0 授權。詳情請參閱《Google Developers 網站政策》。Java 是 Oracle 和/或其關聯企業的註冊商標。
上次更新時間:2020-07-07 (世界標準時間)。
[{
"type": "thumb-down",
"id": "missingTheInformationINeed",
"label":"缺少我需要的資訊"
},{
"type": "thumb-down",
"id": "tooComplicatedTooManySteps",
"label":"過於複雜/步驟過多"
},{
"type": "thumb-down",
"id": "outOfDate",
"label":"過時"
},{
"type": "thumb-down",
"id": "translationIssue",
"label":"翻譯問題"
},{
"type": "thumb-down",
"id": "samplesCodeIssue",
"label":"示例/程式碼問題"
},{
"type": "thumb-down",
"id": "otherDown",
"label":"其他"
}]
[{
"type": "thumb-up",
"id": "easyToUnderstand",
"label":"容易理解"
},{
"type": "thumb-up",
"id": "solvedMyProblem",
"label":"確實解決了我的問題"
},{
"type": "thumb-up",
"id": "otherUp",
"label":"其他"
}]
{"lastModified": "\u4e0a\u6b21\u66f4\u65b0\u6642\u9593\uff1a2020-07-07 (\u4e16\u754c\u6a19\u6e96\u6642\u9593)\u3002"}
[[["容易理解","easyToUnderstand","thumb-up"],["確實解決了我的問題","solvedMyProblem","thumb-up"],["其他","otherUp","thumb-up"]],[["缺少我需要的資訊","missingTheInformationINeed","thumb-down"],["過於複雜/步驟過多","tooComplicatedTooManySteps","thumb-down"],["過時","outOfDate","thumb-down"],["翻譯問題","translationIssue","thumb-down"],["示例/程式碼問題","samplesCodeIssue","thumb-down"],["其他","otherDown","thumb-down"]],["上次更新時間:2020-07-07 (世界標準時間)。"],[],[]]