国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

更優雅的微信小程序骨架屏實現詳解

2019-11-19 11:03:55
字體:
來源:轉載
供稿:網友

一、演示

二、說明:

實現思路:需要默認數據,這樣才能完美應對list,wx:if的情況,及flex寬度靠內容撐開的樣式。

替換思路:和imageLoader加載器類似:先展示默認圖片,拿到數據之后顯示真實的圖片

具體實現:

頁面準備一份默認數據:defaultData

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

頁面onload時,data=defaultData

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

此后,再收到數據就關閉骨架屏

優點:

1.好維護:頁面沒有額外的xml。也沒有額外的css。只需要維護一份默認數據即可。

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

3.可以和imageLoader共處,而不會出現和美團等骨架屏沒有之后,圖片區域還出現短暫空白

4.可定制:

  • 可以共存:文字,圖片/imageLoader,或其它的。低入侵
  • 骨架屏不是一個完整的,而是items,且可以有不同的樣式或過渡
  • 可以完美支持觸底加載時的骨架屏

注意事項:

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

2、custom-class:寬高不需要傳,默認數據就是撐開寬高的

三、代碼:

import { extendComponent} from '../../common/component';extendComponent({ properties: {  watchData: null,//觀察對應的請求對象  transition:{//過渡名稱,對應該組件的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,//第一次顯示骨架屏,之后就顯示真實節點。  success:false //不可逆,只能false->true }})
<!--components/skeleton/skeleton.wxml--><!-- 這里是真實渲染 --><view wx:if="{{success}}" >  <slot /></view><!-- 這里是骨架屏:有動畫情況 --> <transition   wx:elif="{{transition}}"  show="{{true}}"  name="{{ transition }}"  duration="{{800}}"  custom-class="skeleton custom-class" >  <view style="opacity:0;">    <slot />  </view></transition><!-- 這里是骨架屏:無動畫情況 --><view wx:else class="skeleton custom-class">  <view style="opacity:0;">    <slot />  </view></view>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 禄丰县| 博野县| 榆树市| 萝北县| 湖南省| 阿城市| 德庆县| 普兰店市| 辽宁省| 佛冈县| 浠水县| 遂宁市| 册亨县| 革吉县| 长沙市| 专栏| 九龙坡区| 五指山市| 汕尾市| 昆明市| 新疆| 武穴市| 攀枝花市| 甘洛县| 西乌| 台东市| 广德县| 濮阳县| 来凤县| 海盐县| 固镇县| 佳木斯市| 新密市| 温州市| 乌鲁木齐市| 宁武县| 安庆市| 正定县| 普兰店市| 临沭县| 凯里市|