如何在微信小程序中使用骨架屏的步驟
本文介紹了微信小程序中使用骨架屏,分享給大家,具體如下:
先上效果圖
骨架屏主要起到占位作用,向用戶說明該區(qū)域有內(nèi)容,有一定的心理準(zhǔn)備。
聊聊背景:剛上線一款小程序,隨著上架的東西越來越多,微信小程序加載越來越慢,會(huì)出現(xiàn)一段時(shí)間的白屏(大概2-3s),這對(duì)用戶體驗(yàn)上來講特別不友好。所以在網(wǎng)上開始找這方面的資料,骨架屏主要分為兩種方案,下面來說說這兩種方案。
1、為每個(gè)需要使用骨架屏的頁(yè)面定制一套靜態(tài)頁(yè)面。這種方法缺點(diǎn)很明顯,需要為每個(gè)頁(yè)面單獨(dú)定制,布局如果修改則需要同時(shí)修改兩個(gè)頁(yè)面,增加了維護(hù)成本。但這種特別適用于長(zhǎng)列表,只需要做用戶可見的部分,可在一定程度上增加響應(yīng)速度。
2、利用工具渲染頁(yè)面 , 獲取指定的DOM節(jié)點(diǎn)和對(duì)應(yīng)樣式,生成灰色塊覆蓋在原來的樣式結(jié)構(gòu)上,從而實(shí)現(xiàn)骨架屏。這種方式簡(jiǎn)單易用好維護(hù),個(gè)人感覺不太適合在長(zhǎng)列表頁(yè)面。https://github.com/jayZOU/skeleton 這款骨架屏組件輕量、方便、快捷,里面有教程,強(qiáng)烈推薦。
使用哪一種方案,就要根據(jù)自己的項(xiàng)目情況來進(jìn)行選擇了。我采用的是第一種,因?yàn)檫@個(gè)頁(yè)面加載的DOM節(jié)點(diǎn)太多了。從獲取到數(shù)據(jù)后到渲染到頁(yè)面這段時(shí)間有骨架屏做緩沖,效果倍棒。
實(shí)現(xiàn)方法:
1、根據(jù)原有頁(yè)面的結(jié)構(gòu),在重寫一個(gè)靜態(tài)頁(yè)面,把原來用來顯示圖片、文字的地方替換成有灰色背景色的塊。
<!--骨架屏 -->
<view class="sort" wx:if="{{showSkeleton}}">
<scroll-view scroll-y="true" class="sortlist" style="height:{{contentHeight-170}}rpx">
<view class="sort-l" >
<view class="sort-lgj"></view>
</view>
<view class="sort-l" >
<view class="sort-lgj"></view>
</view>
<view class="sort-l" >
<view class="sort-lgj"></view>
</view>
<view class="sort-l" >
<view class="sort-lgj"></view>
</view>
<view class="sort-l" >
<view class="sort-lgj"></view>
</view>
<view class="sort-l" >
<view class="sort-lgj"></view>
</view>
</scroll-view>
</view >
<view class="sort" wx:else>
這里是原來的頁(yè)面
</view >
2、使用一個(gè)變量來控制骨架屏的顯示或隱藏。
onLoad: function(options) {
var that = this
wx.request({
url:'xxxx', //請(qǐng)求地址
data: { //發(fā)送給后臺(tái)的數(shù)據(jù)
xxxx: xxxx
},
header: { //請(qǐng)求頭
"Content-Type": "applciation/json"
},
method: "GET",
success: function(res) {
that.setData({
goodslist: data
})
that.setData({
// 數(shù)據(jù)渲染后
showSkeleton: false
})
},
fail: function(err) {
}
})
}
總結(jié)一下:數(shù)據(jù)較多的頁(yè)面使用骨架屏可以大大提高用戶體驗(yàn)。上文提到的骨架屏組件也是非常好用,幾分鐘就可以上手使用。
初次接觸骨架屏,有理解不到的地方還請(qǐng)多多指正。
到此這篇關(guān)于如何在微信小程序中使用骨架屏的步驟的文章就介紹到這了,更多相關(guān)小程序使用骨架屏內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript高級(jí)程序設(shè)計(jì)(第三版)學(xué)習(xí)筆記1~5章
這篇文章主要介紹了JavaScript高級(jí)程序設(shè)計(jì)(第三版)學(xué)習(xí)筆記1~5章 的相關(guān)資料,需要的朋友可以參考下2016-03-03
解決使用bootstrap的dropdown部件時(shí)報(bào)錯(cuò):error:Bootstrap dropdown require
這篇文章主要介紹了使用bootstrap的dropdown部件時(shí)報(bào)錯(cuò):error:Bootstrap dropdown require Popper.js ,小編把問題描述和解決方案分享給大家,需要的朋友可以參考下2018-08-08
微信小程序?qū)崿F(xiàn)select二級(jí)下拉
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)select二級(jí)下拉效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
圖片自動(dòng)縮小的js代碼,用以防止圖片撐破頁(yè)面
圖片自動(dòng)縮小的js代碼,用以防止圖片撐破頁(yè)面...2007-03-03
javascript中String對(duì)象的slice()方法分析
這篇文章主要介紹了javascript中String對(duì)象的slice()方法,以實(shí)例形式分析了slice()方法的定義、參數(shù)與具體用法,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12
前端微信H5公眾號(hào)實(shí)現(xiàn)授權(quán)登錄的方法總結(jié)
這篇文章主要介紹了如何在微信公眾號(hào)中實(shí)現(xiàn)網(wǎng)頁(yè)授權(quán)功能,包括創(chuàng)建微信服務(wù)公眾號(hào)、配置重定向地址、調(diào)試和開發(fā)使用等步驟,文中通過圖文及代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-01-01

