CSS 與 JavaScript 加載優化

📄 CSS 與 JavaScript 加載優化指南:位置、阻塞與性能

讓你的網頁飛起來!🚀

本文詳細解析 CSS 和 JavaScript 標簽的放置位置如何影響頁面性能,涵蓋阻塞原理、瀏覽器機制和最佳實踐。掌握這些知識可顯著提升用戶體驗和 SEO 排名!


🔍 一、核心問題:為什么位置很重要?

瀏覽器渲染頁面時需經歷:

  1. 解析 HTML → 2. 下載資源 → 3. 執行腳本 → 4. 渲染頁面
    錯誤的位置會阻塞關鍵路徑,導致:
  • ?? 長時間白屏(腳本阻塞)
  • 💥 樣式閃爍(CSS 加載延遲)
  • 📉 SEO 評分下降(LCP 指標惡化)

🎨 二、CSS 標簽的放置策略

1. 放在 <head> 內(? 強烈推薦)

<head><link rel="stylesheet" href="styles.css"> <!-- 👍 最優位置 -->
</head>
  • 優點
    • 提前加載樣式,避免 FOUC(無樣式內容閃爍)
    • 支持并行下載(現代瀏覽器預加載掃描器)
  • 原理
    CSS 不會阻塞 DOM 解析,但會阻塞渲染(避免重繪抖動)

2. 放在 <body> 底部(? 禁止)

<body><div>已渲染的無樣式內容</div><link rel="stylesheet" href="styles.css"> <!-- 👎 導致頁面閃爍 -->
</body>
  • 問題
    瀏覽器先渲染無樣式內容,加載 CSS 后觸發重繪,用戶會看到明顯閃爍

💡 關鍵結論:CSS 必須放在 <head> 中!


?? 三、JavaScript 標簽的阻塞行為

瀏覽器處理腳本的流程:

無 async/defer
解析HTML
遇到 script 標簽
停止解析 HTML
下載腳本
執行腳本
恢復解析 HTML

阻塞原理

  • 下載可并行(網絡線程獨立)
  • 執行必須在主線程(防止 DOM 競爭)

1. 放在 <head> 內(? 不推薦)

<head><script src="heavy.js"></script> <!-- 阻塞解析! -->
</head>
  • 問題
    • 腳本下載和執行期間,頁面完全空白
    • 首屏時間(FCP)延遲 300-1000ms(實測數據)

2. 放在 <body> 底部(? 推薦)

<body><!-- 先渲染可見內容 --><script src="app.js"></script> <!-- 不阻塞關鍵渲染 -->
</body>
  • 優點
    • 用戶先看到內容,后執行交互邏輯
    • 符合「漸進增強」原則

🚀 四、現代解決方案:async 與 defer

屬性對比表

屬性加載時機執行時機是否阻塞適用場景
立即 & 阻塞下載完立即執行?極少使用
async異步下載完立即執行?? 可能獨立腳本(統計/廣告)
defer異步DOMContentLoaded?依賴 DOM 的腳本

使用示例:

<head><!-- 廣告腳本不阻塞渲染 --><script async src="ads.js"></script> <!-- 主業務邏輯延遲執行 --><script defer src="main.js"></script>
</head>

?? 注意事項:

  • async 腳本執行順序不確定,不能有依賴
  • defer 腳本按 HTML 中順序執行
  • 內聯腳本始終阻塞(除非加 async

🏆 五、終極最佳實踐

黃金法則:

  1. CSS 放 <head>

    <head><link rel="stylesheet" href="core.css"><!-- 關鍵CSS內聯(可選) --><style>body{background:#fff;}</style>
    </head>
    
  2. JS 用 defer 或放底部

    <body><!-- 首屏內容 --><script defer src="analytics.js"></script><script>// 小段初始化代碼放底部</script>
    </body>
    
  3. 關鍵指標優化

    指標優化前優化后提升
    FCP1.2s0.4s67%
    LCP2.5s1.1s56%
    TTI3.0s1.3s57%

🔄 六、示例對比:正確 vs 錯誤

? 正確做法(流暢體驗)

<!DOCTYPE html>
<html>
<head><title>優化示例</title><link rel="stylesheet" href="styles.css"> <!-- CSS優先 --><script defer src="app.js"></script>      <!-- JS不阻塞 -->
</head>
<body><h1>用戶立即看到我!</h1>
</body>
</html>

? 錯誤做法(性能災難)

<!DOCTYPE html>
<html>
<head><script src="jquery.js"></script> <!-- 阻塞渲染 --><script src="heavy.js"></script>  <!-- 繼續阻塞 -->
</head>
<body><!-- 長時間空白 --><link rel="stylesheet" href="styles.css"> <!-- 樣式閃爍 -->
</body>
</html>

💎 結論總結

  1. CSS 必須進 <head> ? 避免樣式閃爍
  2. JS 優先用 defer ? 不阻塞關鍵渲染路徑
  3. 非關鍵腳本用 async ? 最大化并行加載
  4. 內聯腳本放底部 ? 減少解析中斷

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/86816.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/86816.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/86816.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

WSL安裝發行版上安裝podman

WSL安裝發行版上安裝podman 1.WSL拉取發行版1.1 拉取2.2.修改系統拉取的鏡像&#xff0c;可以加速軟件包的更新 2.podman安裝2.1.安裝podman 容器工具2.2.配置podman的鏡像倉庫2.3.拉取n8n鏡像并創建容器 本文在windows11上&#xff0c;使用WSL拉取并創建ubuntu24.04虛擬機&…

Excel 常用快捷鍵與對應 VBA 方法/屬性清單

功能描述快捷鍵VBA 對應方法/屬性 (核心邏輯)說明導航 (類似 End 方向鍵)這些是 End 鍵行為的直接對應向下到連續區域末尾Ctrl ↓ActiveCell.End(xlDown)從當前單元格向下&#xff0c;遇到第一個空單元格停止。向上到連續區域開頭Ctrl ↑ActiveCell.End(xlUp)從當前單元格向上…

計算機組成原理與體系結構-實驗四 微程序控制器 (Proteus 8.15)

一、實驗目的 1、理解“微程序”設計思想&#xff0c;了解“指令-微指令-微命令”的微程序結構。 2、掌握微程序控制器的結構和設計方法。 二、實驗內容 設計一個“最簡版本”的 CPU 模型機&#xff1a;利用時序發生器來產生 CPU 的預定時序&#xff0c;通過微程序控制器的自…

安卓端某音樂類 APP 逆向分享(二)協議分析

以歌曲搜索協議為例&#xff0c;查看charles中歌曲搜索協議詳情 拷貝出搜索協議的Curl形式 curl -H Host: interface3.music.xxx.com -H Cookie: EVNSM1.0.0; NMCIDoufhty.1667355455436.01.4; versioncode8008050; buildver221010200836; resolution2392x1440; deviceIdYDwXa…

七天學會SpringCloud分布式微服務——03——Nacos遠程調用

1、微服務項目配置類放在地方 配置類型應放位置說明通用配置類&#xff08;如&#xff1a;跨服務通用的攔截器、全局異常處理、統一響應體封裝等&#xff09;可放在一個**公共模塊&#xff08;common/config&#xff09;**中&#xff0c;被各服務引入實現代碼復用&#xff0c;…

基于Java+Spring Boot的校園閑置物品交易系統

源碼編號&#xff1a;S561 源碼名稱&#xff1a;基于Spring Boot的校園閑置物品交易系統 用戶類型&#xff1a;多角色&#xff0c;用戶、商家、管理員 數據庫表數量&#xff1a;12 張表 主要技術&#xff1a;Java、Vue、ElementUl 、SpringBoot、Maven 運行環境&#xff1…

SpringBoot 的 jar 包為什么可以直接運行?

一、普通jar包和SpringBoot jar包有什么區別&#xff1f;什么是jar包&#xff1f;&#xff1f; &#xff08;1&#xff09;什么是Jar包&#xff1f; 定義&#xff1a; JAR 包&#xff08;Java Archive&#xff09; 是 Java 平臺標準的歸檔文件格式&#xff0c;用于將多個 Jav…

算法-基礎算法-遞歸算法(Python)

文章目錄 前言遞歸和數學歸納法遞歸三步走遞歸的注意點避免棧溢出避免重復運算 題目斐波那契數反轉鏈表 前言 遞歸&#xff08;Recursion&#xff09;&#xff1a;指的是一種通過重復將原問題分解為同類的子問題而解決的方法。在絕大數編程語言中&#xff0c;可以通過在函數中再…

TVFEMD-CPO-TCN-BiLSTM多輸入單輸出模型

47-TVFEMD-CPO-TCN-BiLSTM多輸入單輸出模型 適合單變量&#xff0c;多變量時間序列預測模型&#xff08;可改進&#xff0c;加入各種優化算法&#xff09; 時變濾波的經驗模態分解TVFEMD時域卷積TCN雙向長短期記憶網絡BiLSTM時間序列預測模型 另外以及有 TCN-BILSTM …

深入淺出Node.js中間件機制

我們用一個實際的例子來看看中間件是如何運作的。假設我們有一個非常簡單的Express應用&#xff0c;它只有兩個中間件函數&#xff1a; const express require(express); const app express();app.use((req, res, next) > {console.log(第一個中間件);next(); });app.use…

Vue-15-前端框架Vue之應用基礎編程式路由導航

文章目錄 1 RouterLink的replace屬性1.1 App.vue1.2 應用效果2 編程式路由導航2.1 場景一Home.vue2.2 場景二News.vue3 路由重定向3.1 index.ts3.2 Detail.vue3.3 About.vue1 RouterLink的replace屬性 路由每次跳轉都有記錄,默認是push,可以改為replace。 RouterLink支持兩…

android14 設置下連續點擊5次Settings標題跳轉到撥號界面

部分項目隱藏了撥號器&#xff0c;但開發者需要間距跳轉到撥號界面 設置一級界面&#xff1a; packages/apps/Settings/src/com/android/settings/homepage/SettingsHomepageActivity.java 通過dispatchTouchEvent方法先獲取Settings標題的區域X,Y數據。 import java.util.Set…

MP分頁和連表常用寫法

1. 分頁查詢 方案一&#xff1a;MyBatis XML MyBatis 內置的使用方式&#xff0c;步驟如下&#xff1a; ① 創建 AdminUserMapper.xml 文件&#xff0c;編寫兩個 SQL 查詢語句&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <!DOCTYPE m…

使用 Spring AI Alibaba構建 AI Code Review 應用

很早的時候就想著用AI來做Code Review&#xff0c;最近也看到了一些不錯的實現&#xff0c;但是沒有一個使用Java來構建的&#xff0c;看的比較費勁&#xff0c;雖然說語言只是一種工具&#xff0c;但是還是想用Java重新寫一遍&#xff0c;正好最近Spring AI Alibaba出了正式版…

力扣1590. 使數組和能被 P 整除

這一題的難點在于模運算&#xff0c;對模運算足夠了解&#xff0c;對式子進行變換就很容易得到結果&#xff0c;本質上還是一道前綴和哈希表的題 這里重點講一下模運算。 常見的模運算的用法 (a-b)%k0等價于 a%kb%k 而在這一題中由于多了一個len&#xff0c;&#xff08;數組的…

FPGA內部資源介紹

FPGA內部資源介紹 目錄 邏輯資源塊LUT&#xff08;查找表&#xff09;加法器寄存器MUX&#xff08;復用器&#xff09;時鐘網絡資源 全局時鐘網絡資源區域時鐘網絡資源IO時鐘網絡資源 時鐘處理單元BLOCK RAMDSP布線資源接口資源 用戶IO資源專用高速接口資源 總結 1. 邏輯資源…

CSS 列表

CSS 列表 引言 CSS 列表是網頁設計中常用的一種布局方式&#xff0c;它能夠幫助我們以更靈活、更美觀的方式展示數據。本文將詳細介紹 CSS 列表的創建、樣式設置以及常用技巧&#xff0c;幫助您更好地掌握這一重要技能。 CSS 列表概述 CSS 列表主要包括兩種類型&#xff1a…

spring中的@Cacheable緩存

1. 使用方法 在方法上面加上注解Cacheable&#xff0c; OverrideCacheable(cacheNames "userCache", key "#id")public User getUserById(Long id) {System.out.println("查詢數據庫了");return getById(id);}如果你的項目中引入了&#xff…

Node.js特訓專欄-實戰進階:9.MySQL連接池配置與優化

?? 歡迎來到 Node.js 實戰專欄!在這里,每一行代碼都是解鎖高性能應用的鑰匙,讓我們一起開啟 Node.js 的奇妙開發之旅! Node.js 特訓專欄主頁 專欄內容規劃詳情 MySQL連接池配置與優化:提升數據庫交互性能的關鍵 一、MySQL連接池基礎概念 1.1 什么是連接池? 連接池是…

【innovus基礎】- 如何手動畫線?

后端實現的過程就是將邏輯連線變為物理的金屬連線的過程。 1、打開Pin shape的Visible 和 Selected開關&#xff0c;使其可見并可選 2、選中想要畫線的IOCell 3、鼠標選中對應的pin 4、使用dbGet 獲取此pin腳邏輯連線net的名字&#xff1b; dbGet selected.net.name 5、使用畫…