更優(yōu)雅的微信小程序骨架屏實(shí)現(xiàn)詳解
一、演示


二、說明:
實(shí)現(xiàn)思路:需要默認(rèn)數(shù)據(jù),這樣才能完美應(yīng)對(duì)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={{與卡槽笨蛋一樣的對(duì)象}}><slot/></skeleton>
頁面onload時(shí),data=defaultData
此時(shí):watchData第一次收到數(shù)據(jù)(第一次為onload時(shí)),靠默認(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í):多個(gè)請求,會(huì)看到分批次的替換。而不需要全請求成功才替換。
3.可以和imageLoader共處,而不會(huì)出現(xiàn)和美團(tuán)等骨架屏沒有之后,圖片區(qū)域還出現(xiàn)短暫空白
4.可定制:
- 可以共存:文字,圖片/imageLoader,或其它的。低入侵
- 骨架屏不是一個(gè)完整的,而是items,且可以有不同的樣式或過渡
- 可以完美支持觸底加載時(shí)的骨架屏
注意事項(xiàng):
1、custom-class:需要傳與卡槽一樣的[border-radius];可選[背景色],或者其它
2、custom-class:寬高不需要傳,默認(rèn)數(shù)據(jù)就是撐開寬高的
三、代碼:
import {
extendComponent
} from '../../common/component';
extendComponent({
properties: {
watchData: null,//觀察對(duì)應(yīng)的請求對(duì)象
transition:{//過渡名稱,對(duì)應(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>
<!-- 這里是骨架屏:有動(dòng)畫情況 -->
<transition
wx:elif="{{transition}}"
show="{{true}}"
name="{{ transition }}"
duration="{{800}}"
custom-class="skeleton custom-class"
>
<view style="opacity:0;">
<slot />
</view>
</transition>
<!-- 這里是骨架屏:無動(dòng)畫情況 -->
<view wx:else class="skeleton custom-class">
<view style="opacity:0;">
<slot />
</view>
</view>
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript中的window.location.search方法簡介
window.location.search方法是截取當(dāng)前url中“?”后面的字符串,示例如下,感興趣的朋友可以參考下2013-09-09
uni-app中實(shí)現(xiàn)元素拖動(dòng)效果
這篇文章主要介紹了uni-app中實(shí)現(xiàn)元素拖動(dòng)效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-01-01
js中toString()和String()區(qū)別詳解
本文主要介紹了js中toSring()和Sring()的區(qū)別。具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-03-03
用JavaScript和注冊表腳本實(shí)現(xiàn)右鍵收藏Web頁選中文本
用JavaScript和注冊表腳本實(shí)現(xiàn)右鍵收藏Web頁選中文本...2007-01-01
javascript同頁面多次調(diào)用彈出層具體實(shí)例代碼
一個(gè)在同一個(gè)頁面可多次調(diào)用的javascript彈出層效果,有需要的同學(xué)可以參考一下2013-08-08
Javascript下拉刷新的簡單實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了Javascript下拉刷新的簡單實(shí)現(xiàn)過程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02

