本文實例為大家分享了微信小程序實現動態列表項的順序加載動畫,供大家參考,具體內容如下
效果
思路
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(); }, })
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。