微信小程序如何實(shí)現(xiàn)骨架屏-創(chuàng)新互聯(lián)

這篇文章主要介紹微信小程序如何實(shí)現(xiàn)骨架屏,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

成都創(chuàng)新互聯(lián)公司于2013年成立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項目成都網(wǎng)站建設(shè)、成都網(wǎng)站制作網(wǎng)站策劃,項目實(shí)施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元高碑店做網(wǎng)站,已為上家服務(wù),為高碑店各地企業(yè)和個人服務(wù),聯(lián)系電話:18980820575

一、演示

微信小程序如何實(shí)現(xiàn)骨架屏

微信小程序如何實(shí)現(xiàn)骨架屏

二、說明:

實(shí)現(xiàn)思路:需要默認(rèn)數(shù)據(jù),這樣才能完美應(yīng)對list,wx:if的情況,及flex寬度靠內(nèi)容撐開的樣式。

替換思路:和imageLoader加載器類似:先展示默認(rèn)圖片,拿到數(shù)據(jù)之后顯示真實(shí)的圖片

具體實(shí)現(xiàn):

頁面準(zhǔn)備一份默認(rèn)數(shù)據(jù):defaultData

xml中:<skeleton watchData={{與卡槽笨蛋一樣的對象}}><slot/></skeleton>

頁面onload時,data=defaultData

此時:watchData第一次收到數(shù)據(jù)(第一次為onload時),靠默認(rèn)數(shù)據(jù),撐開卡槽容器,自身opacity:0;

此后,再收到數(shù)據(jù)就關(guān)閉骨架屏

優(yōu)點(diǎn):

1.好維護(hù):頁面沒有額外的xml。也沒有額外的css。只需要維護(hù)一份默認(rèn)數(shù)據(jù)即可。

2.更優(yōu)雅,更真實(shí):多個請求,會看到分批次的替換。而不需要全請求成功才替換。

3.可以和imageLoader共處,而不會出現(xiàn)和美團(tuán)等骨架屏沒有之后,圖片區(qū)域還出現(xiàn)短暫空白

4.可定制:

  • 可以共存:文字,圖片/imageLoader,或其它的。低入侵

  • 骨架屏不是一個完整的,而是items,且可以有不同的樣式或過渡

  • 可以完美支持觸底加載時的骨架屏

注意事項:

1、custom-class:需要傳與卡槽一樣的[border-radius];可選[背景色],或者其它

2、custom-class:寬高不需要傳,默認(rèn)數(shù)據(jù)就是撐開寬高的

三、代碼:

import {
 extendComponent
} from '../../common/component';
extendComponent({
 properties: {
  watchData: null,//觀察對應(yīng)的請求對象
  transition:{//過渡名稱,對應(yīng)該組件的name
   type:String,
   value:null
  }
 },
 observers: {
  "watchData":function(newVal){
   this.data.counter+=1;
   if(this.data.counter>=2){
    this.setData({success:true});
   }
  }
 },
 data: {
  counter:0,//第一次顯示骨架屏,之后就顯示真實(shí)節(jié)點(diǎn)。
  success:false //不可逆,只能false->true
 }
})
<!--components/skeleton/skeleton.wxml-->
<!-- 這里是真實(shí)渲染 -->
<view wx:if="{{success}}" >
  <slot />
</view>

<!-- 這里是骨架屏:有動畫情況 -->
 <transition 
  wx:elif="{{transition}}"
  show="{{true}}"
  name="{{ transition }}"
  duration="{{800}}"
  custom-class="skeleton custom-class"
 >
  <view >
    <slot />
  </view>
</transition>

<!-- 這里是骨架屏:無動畫情況 -->
<view wx:else class="skeleton custom-class">
  <view >
    <slot />
  </view>
</view>

以上是“微信小程序如何實(shí)現(xiàn)骨架屏”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

當(dāng)前標(biāo)題:微信小程序如何實(shí)現(xiàn)骨架屏-創(chuàng)新互聯(lián)
分享網(wǎng)址:http://bm7419.com/article32/hecpc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、虛擬主機(jī)、全網(wǎng)營銷推廣、搜索引擎優(yōu)化用戶體驗(yàn)、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化