本文實例為大家分享了微信小程序實現動態列表項的順序加載動畫,供大家參考,具體內容如下
效果
思路
1、最開始用了純CSS動畫animation,發現動畫需要重復寫,于是換使用transition動畫。
2、使用onReady()可以讓頁面加載好再顯示動畫以免動畫提前結束。
代碼
wxml
<!-- style中的主要為了區分已加載好的項和新數據,只有新數據有動畫 --><view wx:for="{{lists}}" class="common" style='opacity:{{index >= (page-1)*2?op:"1"}};margin-left:{{index >= (page-1)*2?mr:"0"}}rpx;transition:all {{index >= (page-1)*2?(index-(page-1)*2)*0.5+0.5:"0"}}s;' > 第{{index}}條</view> <view bindtap='next' style='position:relative;right:-150px;top:50rpx;'>下一頁</view>
wcss
page{ background: #eee}.common{ height: 100rpx; opacity: 0; margin-left: -50rpx; background: #fff; margin-top: 20rpx; line-height: 100rpx; padding: 25rpx;}
js
Page({ data: { list: ['啦啦啦', '嚯嚯嚯'], lists: ['啦啦啦', '嚯嚯嚯'], page:1 }, onLoad: function (options) { }, onReady:function(e){ this.setData({ op: 1, mr:0 }) }, next:function(e){ this.data.page ++; //模擬從后臺獲取到了下一頁的數據,附加到原有數組上 var lists = this.data.lists.concat(this.data.list) this.setData({ lists:lists, page: this.data.page, op: 0, mr: -50 }) this.onReady(); },})
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答