# CSS 優化 ###### tags:`Frontend` [TOC] > `*` 表示前端要知道但通常由後端來做,這邊講的是概念,實際開發時候可以去選擇工具來達成 ## 資源本身==大小==(把多餘空格移除) * minify,去掉多餘的空、空格,最後變成一整行程式碼,`npx sass --style=compressed main.sass main.css` * gzip* (壓縮),編碼成其他格式 一般兩個會一起做XD ## 資源==載入==方式 * ==CSS sprites== 當要載入的檔案很小但很多時,會增加載入時間,所以要合成大 packages 來傳送,例如很多 icons 的情況 利用 CSS background 屬性的特性來達成,把多個圖片和成一大張圖片,只顯示部分圖片區塊 ![](https://i.imgur.com/MQdAH2E.png) * ==Critical CSS== 當要載入的檔案很大時,會增加載入時間,所以要分成很多小 packages 來傳送 陽春的實作方法就是直接把最重要(使用者直接看到的)的 CSS 放在 HTML 裡面,一點開 HTML 就會出現 * ==Cache*== 當成快取存在使用者端 * ==Data URI== Data URI 是一種檔案格式,它主要是由==base64編碼==之後的結果。用在圖片的載入時,可以先把圖片轉換成文字,然後嵌入程式碼中,這樣就不用再做 request 了,例如 qrcode 就滿適合用的。[補充1](https://medium.com/cubemail88/data-uri-%E5%89%8D%E7%AB%AF%E5%84%AA%E5%8C%96-d83f833e376d)。像下面這段程式碼。 ```htmlmixed= <img src="" /> ``` ## 資源==執行==方式(程式碼的寫法、瀏覽器的執行方式) * 選擇器 Selector 的解析 選擇解析較快的 Selector * 屬性渲染,不同屬性重繪的點不一樣