骨架屏
最近在專案不時有用到骨架屏的需求,所以抽時間對骨架屏的方案作了一下調研,骨架屏的實踐已經有很多了,也有很多人對自己的方案作了介紹.在這裡按照個人的理解做了一個彙總和分類,分享給大家.
關於骨架屏(簡介)
骨架屏就是在頁面資料尚未載入前先給使用者展示出頁面的大致結構,直到請求資料返回後再渲染頁面,補充進需要顯示的資料內容。常用於文章列表、動態列表頁等相對比較規則的列表頁面。
很多專案中都有應用:ex:餓了麼h5版本,知乎,facebook等網站中都有應用。
借個圖舉例如下:
兩類用途
簡介中作了關於用途的說明,但是仍然可以繼續細分:
- 作為spa中路由切換的loading,結合元件的生命週期和ajax請求返回的時機來使用.
- 作為首屏渲染的優化.
第一類用途
第一類用途需要自己編寫骨架屏,推薦兩個成熟方便定製的svg元件定製為骨架屏的方案
作為首屏渲染(自動化方案)
該方案是餓了麼在骨架屏的實踐中總結出的一套方案:
- 骨架屏的dom結構和css通過離線生成後構建的時候注入模板中的節點下面.
- 原理相關eleme骨架屏外掛實現原理
- 方案的專案地址:page-skeleton-webpack-plugin
- 使用時候的注意點:
- cssUnit的配置: 需要使用自適應的單位,按照文件給出的選擇範圍選,直接用
px
生成的比例會不合適 - puppeteer有大概80M, 安裝的時候有可能不能一次下載成功.
- 原理:
通過 puppeteer 在服務端操控 headless Chrome 開啟開發中的需要生成骨架屏的頁面,在等待頁面載入
渲染完成之後,在保留頁面佈局樣式的前提下,通過對頁面中元素進行刪減或增添,對已有元素通過層疊樣
式進行覆蓋,這樣達到在不改變頁面佈局下,隱藏圖片和文字,通過樣式覆蓋,使得其展示為灰色塊。然後
將修改後的 HTML 和 CSS 樣式提取出來,這樣就是骨架屏了.
複製程式碼
其他方案
結合ssr render/prerender來使用:
-
事先編寫好骨架屏元件通過ssr render 解析注入html檔案中(除了需要自己編寫外其實過程類似於上面的自動化方案)參考文章
-
1中事先編寫好的骨架屏元件可以用圖片代替 (svg) ;或者設計師設計好.
小程式的骨架屏
- 不存在預渲染的概念,但是還是可以通過自己預先編寫骨架屏元件放在頁面中,等到非同步請求的資料回來後更新頁面.
廣而告之
本文釋出於薄荷前端週刊,歡迎Watch & Star ★,轉載請註明出處。