微信小程序列表渲染功能之列表下拉刷新及上拉加载的实现方法分析

作者:晚秋星辰 时间:2024-05-11 09:34:44 

本文实例讲述了微信小程序列表渲染功能之列表下拉刷新及上拉加载的实现方法。分享给大家供大家参考,具体如下:

微信小程序为2017年1月9日打下了一个特殊的标签,迅速刷爆了网络和朋友圈,最近我也写了一个demo程序体验一把。微信小程序和vuejs有些像,都是数据驱动视图&单向数据绑定,而其体验要比H5页面好很多,这得益于微信环境的支持以及首次运行时同时加载所有页面的处理。本文将分享微信小程序列表的下拉刷新和上划加载的实践。

效果图

首先来看看程序效果图,以下四张图从左至右依次是:下来刷新动画、下拉刷新结果、上划加载动画以及上划加载结果,程序中的数据均为模拟数据,不包含网络请求,所以可以直接运行。

微信小程序列表渲染功能之列表下拉刷新及上拉加载的实现方法分析

方法一:用scroll-view组件实现

由于最后没有选择这种实现方法(下拉刷新有bug),因此只做简单介绍,当然如果没有下拉刷新的需求,scroll-view组件实现列表的渲染很方便,从官方文档可以看到,scroll-view组件集成了以下方法为编程提供很大便捷。

scroll-into-view String 值应为某子元素id,则滚动到该元素,元素顶部对齐滚动区域顶部
bindscrolltoupper EventHandle 滚动到顶部/左边,会触发 scrolltoupper 事件
bindscrolltolower EventHandle 滚动到底部/右边,会触发 scrolltolower 事件
bindscroll EventHandle 滚动时触发 event.detail = {scrollLeft, scrollTop, scrollHeight, scrollWidth, deltaX, deltaY}

方法二:用page页面自带的功能

Page() 函数用来注册一个页面。接受一个 object 参数,其指定页面的初始数据、生命周期函数、事件处理函数等。

1、在app.json页设置窗口前景色为dark & 允许下拉


"window":{
 "backgroundTextStyle":"dark",
 "navigationBarBackgroundColor": "#000",
 "navigationBarTitleText": "wechat",
 "navigationBarTextStyle":"white",
 "enablePullDownRefresh": true
}

2、在list.json页设置允许下拉


{
 "enablePullDownRefresh": true
}

3、利用onPullDownRefresh监听用户下拉动作

注:在滚动 scroll-view 时会阻止页面回弹,所以在 scroll-view 中滚动无法触发onPullDownRefresh,因此在使用 scroll-view 组件时无法利用page的该特性。


onPullDownRefresh: function() {
wx.showNavigationBarLoading() //在标题栏中显示加载
let newwords = [{message: '从天而降',viewid:'-1',time:util.formatTime(new Date),greeting:'hello'}].concat(this.data.words);
setTimeout( ()=> {
  this.setData({
    words: newwords
  })
  wx.hideNavigationBarLoading() //完成停止加载
  wx.stopPullDownRefresh() //停止下拉刷新
 }, 2000)
}

4、利用onReachBottom页面上拉触底事件

注:,首次进入页面,如果页面不满一屏时会触发 onReachBottom ,应为只有用户主动上拉才触发;手指上拉,会触发多次 onReachBottom,应为一次上拉,只触发一次;所以在编程时需要将这两点考虑在内。


onReachBottom:function(){
 console.log('hi')
 if (this.data.loading) return;
 this.setData({ loading: true });
 updateRefreshIcon.call(this);
 var words = this.data.words.concat([{message: '土生土长',viewid:'0',time:util.formatTime(new Date),greeting:'hello'}]);
 setTimeout( () =>{
   this.setData({
    loading: false,
    words: words
   })
 }, 2000)
}
})

5、上划加载图标动画


/**
* 旋转刷新图标
*/
function updateRefreshIcon() {
var deg = 0;
console.log('旋转开始了.....')
var animation = wx.createAnimation({
 duration: 1000
});
var timer = setInterval( ()=> {
 if (!this.data.loading)
  clearInterval(timer);
 animation.rotateZ(deg).step();//在Z轴旋转一个deg角度
 deg += 360;
 this.setData({
  refreshAnimation: animation.export()
 })
}, 2000);
}

最后附上布局代码:


<view wx:for="{{words}}" class="item-container">
 <view class="items">
   <view class="left">
      <view class="msg">{{item.message}}</view>
      <view class="time">{{item.time}}</view>
   </view>
   <view class="right">{{item.greeting}}</view>
 </view>
</view>
<view class="refresh-block" wx:if="{{loading}}">
<image animation="{{refreshAnimation}}" src="../../resources/refresh.png"></image>
</view>

希望本文所述对大家微信小程序设计有所帮助。

来源:http://blog.csdn.net/dengpeng0419/article/details/54382085

标签:微信小程序,列表渲染
0
投稿

猜你喜欢

  • vue-cli整合vuex的时候,修改actions和mutations,实现热部署的方法

    2024-05-13 09:13:16
  • go语言Timer计时器的用法示例详解

    2024-04-27 15:39:38
  • 详解四种Python中基本形态学滤波的实现

    2023-05-09 15:10:09
  • 深入了解Vue组件七种通信方式

    2024-04-27 16:03:01
  • 全面分析Python的优点和缺点

    2023-11-09 11:00:07
  • Pandas 同元素多列去重的实例

    2023-02-09 21:03:32
  • Python读取Excel数据实现批量生成合同

    2022-08-15 02:12:12
  • PHP substr()函数参数解释及用法讲解

    2023-11-24 11:47:56
  • 如何用用Python制作NFT区块链作品

    2022-11-21 22:51:09
  • Python爬虫实现网页信息抓取功能示例【URL与正则模块】

    2023-12-09 05:15:03
  • adonet基础示例分享(adonet连接数据库)

    2024-01-15 23:15:44
  • asp如何制作一个WAP手机的WML网页?

    2010-06-29 21:21:00
  • Python selenium文件上传下载功能代码实例

    2021-04-24 07:21:28
  • python数据类型强制转换实例详解

    2022-02-08 05:22:43
  • 优化SQL Server的内存占用之执行缓存

    2012-04-13 11:45:06
  • python re正则匹配网页中图片url地址的方法

    2023-06-15 20:44:20
  • go build失败报方法undefined的解决过程

    2023-06-18 15:07:36
  • Python可变集合和不可变集合的构造方法大全

    2021-10-23 12:39:04
  • 在SQL SERVER中导致索引查找变成索引扫描的问题分析

    2024-01-20 09:19:35
  • Vue.js鼠标悬浮更换图片功能

    2024-04-30 10:42:35
  • asp之家 网络编程 m.aspxhome.com