摘要:常用于文章列表動態列表頁等相對比較規則的列表頁面。很多項目中都有應用餓了么版本知乎等網站中都有應用。歡迎討論,點個贊再走吧
骨架屏
最近在項目不時有用到骨架屏的需求,所以抽時間對骨架屏的方案作了一下調研,骨架屏的實踐已經有很多了,也有很多人對自己的方案作了介紹.在這里按照個人的理解做了一個匯總和分類,分享給大家.
關于骨架屏(簡介)骨架屏就是在頁面數據尚未加載前先給用戶展示出頁面的大致結構,直到請求數據返回后再渲染頁面,補充進需要顯示的數據內容。常用于文章列表、動態列表頁等相對比較規則的列表頁面。
很多項目中都有應用:ex:餓了么h5版本,知乎,facebook等網站中都有應用。
借個圖舉例如下:
簡介中作了關于用途的說明,但是仍然可以繼續細分:
作為spa中路由切換的loading,結合組件的生命周期和ajax請求返回的時機來使用.
作為首屏渲染的優化.
第一類用途第一類用途需要自己編寫骨架屏,推薦兩個成熟方便定制的svg組件定制為骨架屏的方案
react-content-loader
vue-content-loader
作為首屏渲染(自動化方案)該方案是餓了么在骨架屏的實踐中總結出的一套方案:
骨架屏的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 ★,轉載請注明出處。
歡迎討論,點個贊再走吧 ????? ~文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/53063.html
摘要:可以通過的提供的直接控制模擬大部分用戶操作來進行或者作為爬蟲訪問頁面來收集數據。 ??骨架屏是在頁面數據尚未加載完成前先給用戶展示出頁面的大致結構,直到請求數據返回后再顯示真正的頁面內容;隨著單頁應用( SPA )的越來越流行,單頁應用的用戶體驗也越來越得到前端開發者的關注;為了優化用戶體驗,在數據到達用戶之前,往往會在頁面上加上 loading 的效果,而現在,越來越多的場景傾向于使...
github 地址: VV-UI/VV-UI 演示地址: vv-ui 文檔地址:skeleton 關于骨架屏介紹 骨架屏的作用主要是在網絡請求較慢時,提供基礎占位,當數據加載完成,恢復數據展示。這樣給用戶一種很自然的過渡,不會造成頁面長時間白屏或者閃爍等情況。 常見的骨架屏實現方案有ssr服務端渲染和prerender兩種解決方案。這里主要通過代碼為大家展示如何一步步做出這樣一個骨架屏: show...
github 地址: VV-UI/VV-UI 演示地址: vv-ui 文檔地址:skeleton 關于骨架屏介紹 骨架屏的作用主要是在網絡請求較慢時,提供基礎占位,當數據加載完成,恢復數據展示。這樣給用戶一種很自然的過渡,不會造成頁面長時間白屏或者閃爍等情況。 常見的骨架屏實現方案有ssr服務端渲染和prerender兩種解決方案。這里主要通過代碼為大家展示如何一步步做出這樣一個骨架屏: show...
閱讀 644·2023-04-25 15:49
閱讀 3099·2021-09-22 15:13
閱讀 1235·2021-09-07 10:13
閱讀 3467·2019-08-29 18:34
閱讀 2555·2019-08-29 15:22
閱讀 499·2019-08-27 10:52
閱讀 677·2019-08-26 18:27
閱讀 3009·2019-08-26 13:44