最近在項目不時有用到骨架屏的需求,因此抽時間對骨架屏的方案做了一下調研,骨架屏的實踐已經有不少了,也有不少人對本身的方案做了介紹.在這裏按照我的的理解作了一個彙總和分類,分享給你們.css
骨架屏就是在頁面數據還沒有加載前先給用戶展現出頁面的大體結構,直到請求數據返回後再渲染頁面,補充進須要顯示的數據內容。經常使用於文章列表、動態列表頁等相對比較規則的列表頁面。
不少項目中都有應用:ex:餓了麼h5版本,知乎,facebook等網站中都有應用。
借個圖舉例以下:
html
簡介中做了關於用途的說明,可是仍然能夠繼續細分:vue
第一類用途須要本身編寫骨架屏,推薦兩個成熟方便定製的svg組件定製爲骨架屏的方案react
該方案是餓了麼在骨架屏的實踐中總結出的一套方案:webpack
px
生成的比例會不合適經過 puppeteer 在服務端操控 headless Chrome 打開開發中的須要生成骨架屏的頁面,在等待頁面加載 渲染完成以後,在保留頁面佈局樣式的前提下,經過對頁面中元素進行刪減或增添,對已有元素經過層疊樣 式進行覆蓋,這樣達到在不改變頁面佈局下,隱藏圖片和文字,經過樣式覆蓋,使得其展現爲灰色塊。而後 將修改後的 HTML 和 CSS 樣式提取出來,這樣就是骨架屏了.
結合ssr render/prerender來使用:git