微信小程序之分页加载的的案例

互联网 17-9-13
本篇文章主要介绍了微信小程序分页加载的实例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

整理文档,搜刮出一个微信小程序分页加载的代码,稍微整理精简一下做下分享。

分页加载功能大家遇到的应该会经常遇到,应用场景也很多,例如微博,QQ,微信朋友圈以及新闻类应用,都会有分页加载的功能,这不仅节省了我们用户的流量,还提升了用户体验。那么今天的这篇文章就是介绍微信小程序中如何实现分页加载的功能。照例先上源码及效果图。

源码传送门

要实现这样的功能,一般需要在请求数据时加入当前请求页数,以及页的大小(每页显示的数量)也有一部分接口是通过请求的开始偏移量和结束偏移量请求数据,例如你一页显示10条数据,第一次(第一页)请求即开始start为0结束end是9,第二页就是从10到19,以此类推。

既然要实现分页加载功能,最重要就是下拉以及上拉的处理事件,在微信小程序中已经帮我们封装好了上拉以及下拉的触发事件,如下

/**   * 页面相关事件处理函数--监听用户下拉动作   */   onPullDownRefresh: function () {   },     /**    * 页面上拉触底事件的处理函数    */   onReachBottom: function () {   },

可能刚接触微信小程序的爱好者,会遇到一个问题,为什么我重写了上拉和下拉函数,但是当我上拉或者下拉的时候函数为什么不回调啊。莫急莫慌,那是因为除了重写这两个函数,我们还需要在json配置文件加入下面代码

{    "enablePullDownRefresh": true  }

在data中创建数据

 data: {    page: 1,    pageSize: 30,    hasMoreData: true,    contentlist: [],   },

page即为当前请求数据时第几页,pageSize是每页的数据的大小,hasMoreData用于上拉的时候是不是要继续请求数据,即是不是还有更多数据。当我们网络请求数据成功后,如果请求数据的长度小于pageSize: 30,那么就表示没有更多数据,将hasMoreData更改为false,如果请求的数据长度是30,表示还有更多数据那么hasMoreData久更改为true,并将页数page加1.当下拉的时候讲page先更改为1,然后去查询数据,当查询数据成功时,如果page为1,就将获取的数据直接赋值给contentlist,如果页数大于1的话,就将请求的数据追加在contentlist后面。这样就可以实现分页加载的功能了。

经过上面的分析,我们已经对分页加载的实现有了一个清晰的认识,那么接下来我就介绍代码的实现。

 getMusicInfo: function (message) {    var that = this    var data = {     showapi_appid: '25158',     showapi_sign: 'c0d685445898438f8c12ee8e93c2ee74',     keyword: '我',     page: that.data.page    }    network.requestLoading('https://route.showapi.com/213-1', data, message, function (res) {     console.log(res)     var contentlistTem = that.data.contentlist     if (res.showapi_res_code == 0) {      if (that.data.page == 1) {       contentlistTem = []      }      var contentlist = res.showapi_res_body.pagebean.contentlist      if (contentlist.length < that.data.pageSize) {       that.setData({        contentlist: contentlistTem.concat(contentlist),        hasMoreData: false       })      } else {       that.setData({        contentlist: contentlistTem.concat(contentlist),        hasMoreData: true,        page: that.data.page + 1       })      }     } else {      wx.showToast({       title: res.showapi_res_error,      })     }      }, function (res) {     wx.showToast({      title: '加载数据失败',     })      })   },

那么我们当进入页面的时候开始加载一次数据,即在onLoad函数,如下

 onLoad: function (options) {    // 页面初始化 options为页面跳转所带来的参数    var that = this    that.getMusicInfo('正在加载数据...')   },

然后上拉和下拉函数的实现如下

 /**   * 页面相关事件处理函数--监听用户下拉动作   */   onPullDownRefresh: function () {    this.data.page = 1    this.getMusicInfo('正在刷新数据')   },     /**    * 页面上拉触底事件的处理函数    */   onReachBottom: function () {    if (this.data.hasMoreData) {     this.getMusicInfo('加载更多数据')    } else {     wx.showToast({      title: '没有更多数据',     })    }   },

以上就是微信小程序之分页加载的的案例的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: 的的
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:微信小程序实现共用变量值的方法介绍

相关资讯