微信小程序开发之分页加载
凌雪 2018-10-10 来源 :网络 阅读 5403 评论 0

摘要:本文将带你了解微信小程序开发之分页加载,希望本文对大家学微信有所帮助。

本文将带你了解微信小程序开发之分页加载,希望本文对大家学微信有所帮助。


分页加载功能大家遇到的应该会经常遇到,应用场景也很多,例如微博,QQ,微信朋友圈以及新闻类应用,都会有分页加载的功能,这不仅节省了我们用户的流量,还提升了用户体验。那么今天的这篇文章就是介绍微信小程序中如何实现分页加载的功能。照例先上源码及效果图。源码传送门music.gif要实现这样的功能,一般需要在请求数据时加入当前请求页数,以及页的大小(每页显示的数量)也有一部分接口是通过请求的开始偏移量和结束偏移量请求数据,例如你一页显示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: '加载数据失败',
          })
   
        })
      },上面函数就是获取音乐列表信息的请求处理逻辑,该函数有一个参数message,它是用来展示加载数据时的提示信息,例如当下拉的时候,提示信息为正在刷新数据,当上拉的时候提示正在加载更多数据。那么我们当进入页面的时候开始加载一次数据,即在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: '没有更多数据',
          })
        }
      },    

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

本文由 @凌雪 发布于职坐标。未经许可,禁止转载。
喜欢 | 7 不喜欢 | 6
看完这篇文章有何感觉?已经有13人表态,54%的人喜欢 快给朋友分享吧~
评论(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小时内训课程