微信开发之列表上拉加载更多的实现
白羽 2018-06-14 来源 :网络 阅读 1656 评论 0

摘要:本文将带你了解微信开发之列表上拉加载更多的实现,希望本文对大家学微信有所帮助。


微信小程序API提供了监听页面用户下拉刷新事件,但是没有提供上拉监听事件,实际开发过程中经常会用到上拉列表,加载更多的需求。那么如何实现呢? 
实现原理:利用onReachBottom监听页面滑动到底部,然后执行具体的函数方法,例如请求数据,然后将列表数据进行重新赋值。 
先看看页面效果图: 
(加载更多数据) 
 微信开发之列表上拉加载更多的实现(数据加载完毕) 

微信开发之列表上拉加载更多的实现 
代码如下:

<!--index.wxml--><view class="class_list">
  <view class="class_item" wx:for="{{list_data}}">
    item{{item}}
  </view>
  <view class="class_item class_item_end">
    {{title}}
  </view></view>
/**index.wxss**/.class_list{
  background-color: #fff;
  color: #000;}.class_item{
  border-bottom: solid #f5f5f5 1px;
  padding: 20px;}.class_item_end{
  text-align: center;}page{
  background-color: #f5f5f5;}
//index.js
Page({
  data:{
    list_data:[],
    title:"正在加载数据..."
  },
  onLoad: function () {
    var that = this
    that.setData({
      list_data:[0,1,2,3,4,5,6,7,8,9]
    })
  },
  onReachBottom: function () {
    var that = this
    setTimeout(function(){
      that.setData({
        list_data: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19],
        title: "数据加载完毕"
      })
    },1000)
  }
})


上面代码难度不大,看上去也很易懂,在onReachBottom中使用了setTimeout()模拟请求时间,真实开发中换做https请求。 


虽然这是一个完整的demo,但是还有很多小瑕疵,各位初学者可以自行尝试解决: 
1、如何改为真实的https请求? 
2、如果一次请求还没收到返回值,再次调用了该方法,如何避免重复调用https? 
3、尝试结合API中的下拉加载更多,实现一个完整的demo 
4、现在监听的是滑动到页面底部,但是实际情况下,应该当最下面“正在加载数据…”这一栏顶部出现在页面可视部分,就执行发送请求方法。


 


本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标移动开发之微信频道!


本文由 @白羽 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程