不懂在微信小程序中實(shí)現(xiàn)骨架屏的方法?其實(shí)想解決這個(gè)問(wèn)題也不難,下面讓小編帶著大家一起學(xué)習(xí)怎么去解決,希望大家閱讀完這篇文章后大所收獲。
站在用戶的角度思考問(wèn)題,與客戶深入溝通,找到云浮網(wǎng)站設(shè)計(jì)與云浮網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、國(guó)際域名空間、雅安服務(wù)器托管、企業(yè)郵箱。業(yè)務(wù)覆蓋云浮地區(qū)。
先上效果圖
​
骨架屏主要起到占位作用,向用戶說(shuō)明該區(qū)域有內(nèi)容,有一定的心理準(zhǔn)備。
聊聊背景:剛上線一款小程序,隨著上架的東西越來(lái)越多,微信小程序加載越來(lái)越慢,會(huì)出現(xiàn)一段時(shí)間的白屏(大概2-3s),這對(duì)用戶體驗(yàn)上來(lái)講特別不友好。所以在網(wǎng)上開(kāi)始找這方面的資料,骨架屏主要分為兩種方案,下面來(lái)說(shuō)說(shuō)這兩種方案。
1、為每個(gè)需要使用骨架屏的頁(yè)面定制一套靜態(tài)頁(yè)面。這種方法缺點(diǎn)很明顯,需要為每個(gè)頁(yè)面單獨(dú)定制,布局如果修改則需要同時(shí)修改兩個(gè)頁(yè)面,增加了維護(hù)成本。但這種特別適用于長(zhǎng)列表,只需要做用戶可見(jiàn)的部分,可在一定程度上增加響應(yīng)速度。
2、利用工具渲染頁(yè)面 ,獲取指定的DOM節(jié)點(diǎn)和對(duì)應(yīng)樣式,生成灰色塊覆蓋在原來(lái)的樣式結(jié)構(gòu)上,從而實(shí)現(xiàn)骨架屏。這種方式簡(jiǎn)單易用好維護(hù),個(gè)人感覺(jué)不太適合在長(zhǎng)列表頁(yè)面。https://github.com/jayZOU/skeleton 這款骨架屏組件輕量、方便、快捷,里面有教程,強(qiáng)烈推薦。
使用哪一種方案,就要根據(jù)自己的項(xiàng)目情況來(lái)進(jìn)行選擇了。我采用的是第一種,因?yàn)檫@個(gè)頁(yè)面加載的DOM節(jié)點(diǎn)太多了。從獲取到數(shù)據(jù)后到渲染到頁(yè)面這段時(shí)間有骨架屏做緩沖,效果倍棒。
實(shí)現(xiàn)方法:
1、根據(jù)原有頁(yè)面的結(jié)構(gòu),在重寫(xiě)一個(gè)靜態(tài)頁(yè)面,把原來(lái)用來(lái)顯示圖片、文字的地方替換成有灰色背景色的塊。
<!--骨架屏 --> <view class="sort" wx:if="{{showSkeleton}}"> <scroll-view scroll-y="true" class="sortlist" > <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> 這里是原來(lái)的頁(yè)面 </view >
2、使用一個(gè)變量來(lái)控制骨架屏的顯示或隱藏。
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) { } }) }
數(shù)據(jù)較多的頁(yè)面使用骨架屏可以大大提高用戶體驗(yàn)。上文提到的骨架屏組件也是非常好用,幾分鐘就可以上手使用。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享在微信小程序中實(shí)現(xiàn)骨架屏的方法內(nèi)容對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,遇到問(wèn)題就找創(chuàng)新互聯(lián),詳細(xì)的解決方法等著你來(lái)學(xué)習(xí)!
網(wǎng)頁(yè)標(biāo)題:在微信小程序中實(shí)現(xiàn)骨架屏的方法
網(wǎng)站路徑:http://newbst.com/article12/jhcodc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)公司、微信公眾號(hào)、ChatGPT、搜索引擎優(yōu)化、網(wǎng)站維護(hù)、移動(dòng)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)