溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

在微信小程序中實(shí)現(xiàn)骨架屏的方法

發(fā)布時(shí)間:2020-06-23 15:52:10 來源:億速云 閱讀:760 作者:清晨 欄目:web開發(fā)

不懂在微信小程序中實(shí)現(xiàn)骨架屏的方法?其實(shí)想解決這個(gè)問題也不難,下面讓小編帶著大家一起學(xué)習(xí)怎么去解決,希望大家閱讀完這篇文章后大所收獲。

先上效果圖

在微信小程序中實(shí)現(xiàn)骨架屏的方法 ​

骨架屏主要起到占位作用,向用戶說明該區(qū)域有內(nèi)容,有一定的心理準(zhǔn)備。

聊聊背景:剛上線一款小程序,隨著上架的東西越來越多,微信小程序加載越來越慢,會(huì)出現(xiàn)一段時(shí)間的白屏(大概2-3s),這對(duì)用戶體驗(yàn)上來講特別不友好。所以在網(wǎng)上開始找這方面的資料,骨架屏主要分為兩種方案,下面來說說這兩種方案。

1、為每個(gè)需要使用骨架屏的頁面定制一套靜態(tài)頁面。這種方法缺點(diǎn)很明顯,需要為每個(gè)頁面單獨(dú)定制,布局如果修改則需要同時(shí)修改兩個(gè)頁面,增加了維護(hù)成本。但這種特別適用于長(zhǎng)列表,只需要做用戶可見的部分,可在一定程度上增加響應(yīng)速度。

2、利用工具渲染頁面 , 獲取指定的DOM節(jié)點(diǎn)和對(duì)應(yīng)樣式,生成灰色塊覆蓋在原來的樣式結(jié)構(gòu)上,從而實(shí)現(xiàn)骨架屏。這種方式簡(jiǎn)單易用好維護(hù),個(gè)人感覺不太適合在長(zhǎng)列表頁面。https://github.com/jayZOU/skeleton 這款骨架屏組件輕量、方便、快捷,里面有教程,強(qiáng)烈推薦。

使用哪一種方案,就要根據(jù)自己的項(xiàng)目情況來進(jìn)行選擇了。我采用的是第一種,因?yàn)檫@個(gè)頁面加載的DOM節(jié)點(diǎn)太多了。從獲取到數(shù)據(jù)后到渲染到頁面這段時(shí)間有骨架屏做緩沖,效果倍棒。

實(shí)現(xiàn)方法:

1、根據(jù)原有頁面的結(jié)構(gòu),在重寫一個(gè)靜態(tà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>

  這里是原來的頁面

</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) {    

    }

  })
}

數(shù)據(jù)較多的頁面使用骨架屏可以大大提高用戶體驗(yàn)。上文提到的骨架屏組件也是非常好用,幾分鐘就可以上手使用。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享在微信小程序中實(shí)現(xiàn)骨架屏的方法內(nèi)容對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,遇到問題就找億速云,詳細(xì)的解決方法等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI