加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

微信小程序中列表上拉加载的实现方法(附代码)

发布时间:2020-12-14 20:02:56 所属栏目:资源 来源:网络整理
导读:本篇文章给大家带来的内容是关于微信小程序中列表上拉加载的实现代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 某个页面,有多个列表,如100行,这时需要实现分页功能,手机端的分页一般都是滑到底部时上拉刷新。 使用scroll-view

本篇文章给大家带来的内容是关于微信小程序中列表上拉加载的实现代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

某个页面,有多个列表,如100行,这时需要实现分页功能,手机端的分页一般都是滑到底部时上拉刷新。

使用scroll-view实现,其bindscrolltolower方法:滚动到底部/右边触发。当触发时发送请求获取新的数据,我写的时候获取的数据很快,我还给它加了个定时器啊哈哈哈,因为我想让showLoading加载弹窗转一转,让用户知道上拉刷新数据。因为没加的时候showLoading一闪而过,感觉体验效果不好。

最后scroll-view使用竖向滚动时,需要给一个固定高度(height:93%),再给page设置高度(height:100%),否则bindscrolltolower触发不了


来一段逻辑的代码

  //上拉加载分页
  getMore(e){
    var that = this;
    var user = wx.getStorageSync('bizUser');
    wx.showLoading({
      title: '正在加载中',});
    setTimeout(function(){
      var pageindex = that.data.curPage;
      var student = that.data.student;
      if (pageindex>=1){
        ++pageindex;
      }
      wx.request({
        url: app.url + '',data: {
          schoolId: user.schoolId,pageSize: 10,curPage:pageindex
        },method: 'GET',success:function(res){
          if (res.data.data) {
            var studentLength = (res.data.data instanceof Array) ? res.data.data.length : 0;
            for (var i = 0; i < studentLength; i++) {
              //判断计时付或一次性
              if (res.data.data[i].sign_type == 2) {
                res.data.data[i].sign_type = '一次性';
              } else if (res.data.data[i].sign_type == 1) {
                res.data.data[i].sign_type = '计时付';
              } else if (res.data.data[i].sign_type == 3) {
                res.data.data[i].sign_type = '计时付';
              } else if (res.data.data[i].sign_type == 4) {
                res.data.data[i].sign_type = '一次性';
              } else if (res.data.data[i].sign_type = 5) {
                res.data.data[i].sign_type = '一次性'
              }
          //数字变中文
          if (res.data.data[i].learn_stage == 1) {
            res.data.data[i].learn_stage = &#39;一&#39;;
          } else if (res.data.data[i].learn_stage == 2) {
            res.data.data[i].learn_stage = &#39;二&#39;;
          } else if (res.data.data[i].learn_stage == 3) {
            res.data.data[i].learn_stage = &#39;三&#39;
          }
        }

        if (studentLength ==10) {
          for (var j = 0; j < studentLength;j++){
            student.push(res.data.data[j]);
          }
          that.setData({
            student: student,load: &#39;上拉加载更多..&#39;,curPage: pageindex
          })


        } else if (studentLength<10){
          for (var j = 0; j < studentLength; j++) {
            student.push(res.data.data[j]);
          }
          that.setData({
            student: student,load: &#39;已经没有更多了..&#39;,curPage: pageindex
          })
        }
      } else {
        that.setData({
          load: &#39;已经没有更多了&#39;
        })
      }
    }
  })

  wx.hideLoading();

},500)

},

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读