vue实践:better-scroll上拉加载数据后,上拉失效

我在做vue页面的时候遇到的这个问题,之前也遇到过当时给忽略了。

代码重现:

html:

      <div class="doctor-content" ref="doctorContentBox">
        <div>
          <div class="item" v-for="(item, index) in doctorList" :key="index">
            。。。
          </div>
        </div>
      </div>

js:

  mounted () {
    this.$nextTick(() => {
      setTimeout(() => {
        this.doctorBox = new this.$BScroll(this.$refs.doctorContentBox, {
          click: true,
          scrollX: false,
          scrollY: true,
          bounce: true,
          probeType: 3,
          pullUpLoad: {
            threshold: -30 // 当上拉距离超过30px时触发 pullingUp 事件
          }
        });
        /* 上拉加载更多 */
        this.doctorBox.on('pullingUp', () => {
          this.pages++;
          this.getDoctorList('', this.pages);
          this.doctorBox.finishPullUp(); // 事情做完,需要调用此方法告诉 better-scroll 数据已加载,否则上拉事件只会执行一次
        });
      }, 500);
    });
  },

在某些时候,这样的写法上拉加载后依旧可以上滑,切上滑不会失效,but,有时候就失效了。

问题描述:在设置上拉加载数据后,页面上上拉加载,函数getDoctorList执行,页面新添加数据,加载成功,但是,上拉此时不能往下滑动,只能在最初的那一个页面执行上下的滑动,也就是说滑不到最新加载的那些数据,而那些数据是存在页面上的。

解决:

/* 上拉加载更多 */
        this.doctorBox.on('pullingUp', () => {
          this.pages++;
          this.getDoctorList('', this.pages);
          this.doctorBox.finishPullUp(); // 事情做完,需要调用此方法告诉 better-scroll 数据已加载,否则上拉事件只会执行一次
          setTimeout(() => {
            this.doctorBox.refresh();
          }, 500);
        });

添加一个refresh函数,你也可以不用setTimeOut,但那样加载的过程会比较僵硬,没有一点弹性。

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mosowe

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值