[week 13] 前端進階 - 如何優化執行 CSS 效能
- 發佈時間
前端優化#
關於前端優化方式,可從下列幾個方向進行:
- 資源本身的大小
- 資源載入的方式
- 資源執行的方式
CSS 優化#
節省資源大小#
- Minify:省略空白字元,電腦可直接辨識
- 例如:
nps sass --style=compressed main.sass masin.css
- 例如:
- gzip*:壓縮,會進行編碼,通常是在 server 端進行,電腦會經過解碼後再使用
通常會先進行 Minify 再進行 gzip*,藉此壓縮資源大小。
載入方式#
- Critical CSS:分批載入,先載入重要的部分
- 例如:把 navbar、banner 樣式放到 index.html,在讀取 css 之前即可先被載入
- CSS Sprites:將每個小檔案打包後,只需發出一個 Request ,載入完成後再拆開引用
- 例如:將小圖片打包成大圖片,再取用需要的區塊
- Cache*:將資料暫存在瀏覽器,只有第一次登入網站需下載,之後就能快速讀取暫存檔
執行方式#
-
選擇器:降低選擇器的複雜性
- 例如:使用 Sass 巢狀語法時,需考慮到編譯後程式碼的複雜性
-
屬性渲染:需考慮到屬性載入的順序
- 例如:特效網頁或有 SEO 考量的網站,需注意動畫或特效會在哪個階段匯入
CSS Sprites 與 Data URI 的優缺點#
CSS Sprites#
CSS Sprite 是將頁面中所使用到的小圖片整合到一張大圖上。也就是說,在加載一個包含多個圖片的頁面上時,只需使用一個 HTTP 請求而不需要 JavaScript 代碼。
- 優點:減少 http 請求
- 缺點:圖片合併定位費時費力
使用技巧#
- 切圖前就需構思拼接好圖片
- 排序有序,便於後期維護。有利於 background-position 定位
- 定位時避免使用 right, bottom 等
- 合理預留空白位置(空太多檔案變大,太小引起圖示重疊)
Data URI#
image data URI 是將圖片資源轉換為 base64 字串格式嵌到頁面或樣式中。不需要圖片的請求連結。
- 優點:
- 減少 HTTP 請求
- 避免某些檔案跨域
- 無圖片快取等問題
- 缺點:
- 相容性(IE6,7 不相容,可使用 MHTML 來解決)
- 瀏覽器不會快取該圖片
- 增加 css 檔案大小
- 編碼成本及維護
使用技巧#
- data URI 可使用在:
- 圖片尺寸很小,使用一條 http 請求有點浪費,如:漸變背景框
- 圖片在全站大規模使用,且很少被更新的,如:loading 圖
- 標籤語法
- data:取得資料協議
- image/png:取得資料的協議名稱(注意這裡也圖片資源也可以使用字型等)
- base64:資料編碼方式
- iVBOR…:編碼後資料
參考資料: