vue使用better-scroll实现下拉刷新和上拉加载,文末附文档

背景

在使用VUE 开发APP过程中由于uniapp各项限制,决定弃用,直接使用VUE-CLI进行开发。其中遇到的一个问题就是上拉加载和下来刷新的问题,直接使用window.addEventListener scroll在移动端是无效的。后来采用了better-scroll库实现,但是在使用时发现在理解上有些问题导致期初使用有点疙瘩,这里梳理一下逻辑,最后附上代码。

逻辑

展示部分

其实better-scroll库的逻辑很简单,繁琐的是配置和文档。基本逻辑就是外框固定高度或宽度小于内框(取决于你想用来做纵向还是横向移动),使我们在外框的空间里做内框的移动。这里是做上拉加载和下拉刷新,所以只需要限定高度。这里就是我们的HTML和CSS部分,容易出现问题的是
高度未设置或外框大于内框(见CSS写法)

逻辑部分

JS中配置笔记简单,无非就是
1.实例化对象
2.对象配置
3.对象监听
4.监听方法。

其实很简单,但是由于我在使用过程中没有认真阅读文档,所以踩了很多坑:

1.实例化对象部分容易出现的问题是:scroll对象没有定义在外框上(见JS的实例化部分)
2.对象配置的写法一定要认真跟文档走,例如scrollY默认是开启的,而scrollX则默认是关闭的,对象中的click事件默认是关闭的,不知道的话写完了发现里面的项目无法点击等问题。再如pullUpLoad等的设置有它明确的设置项,再入监听方法也是固定的几项(再次提醒,一定好好阅读文档,文末参考链接中第二条)
3.对象监听,详细监听事件还是去文末看文档,另外有人提问反馈的一个低级错误也说一下,监听事件写在mounted中。
4.监听方法一般没什么坑可以踩。

小结

所以这里明确了几件事
1.外框固定高度
2.内框高>外框
3.scroll对象配置属性
4.scroll对象启用监听

代码

HTML

<div class='con' ref="wr">
    <div>
      <div class='num' v-for='(item,index) in items' :key='index'>{{item}}</div>
    </div>
 </div>

JS

import BScroll from 'better-scroll'	//引入better-scroll库
export default {
  data () {
    return {
      scroller:null,
      items:[1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23],
    }
  },
   methods:{
   },
   mounted(){
    this.scroller=new BScroll(this.$refs.wr,{		//定义滚动器
      scrollY:true,
      click:true,		//启用点击事件
      pullUpLoad:{		//启用上拉配置
        threshold:50,	//上拉动作触发距离
      }  
    });
    this.scroller.on('pullingUp',()=>{
      console.log("上拉加载");
    })
   }
}

CSS

.con{
  height: 60vh;
  overflow: hidden;
  background: #ddd;
}
.num{
  height: 30px;
}

参考

1.npm官方(虽然是官方,但是内容太少不实用)
2.better-scroll文档,各项配置看这里
3.看了我的文章还没看懂,又没耐心的可以看B站视频

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用better-scroll实现刷新和上功能,需要先安装better-scroll插件。 1. 安装better-scroll ```bash npm install better-scroll --save ``` 2. 导入better-scroll ```javascript import BScroll from 'better-scroll' ``` 3. 创建better-scroll实例 ```javascript mounted() { this.initScroll() }, methods: { initScroll() { this.scroll = new BScroll(this.$refs.wrapper, { probeType: 3, // 实时派发scroll事件 click: true, // 开启点击事件 pullDownRefresh: true, // 开启下刷新 pullUpLoad: true // 开启上 }) } }, ``` 4. 监听下刷新和上事件 ```javascript this.scroll.on('pullingDown', () => { // 下刷新业务逻辑 this.scroll.finishPullDown() // 完成下刷新 this.scroll.refresh() // 重新计算滚动区域 }) this.scroll.on('pullingUp', () => { // 上业务逻辑 this.scroll.finishPullUp() // 完成上 this.scroll.refresh() // 重新计算滚动区域 }) ``` 5. 在模板中添DOM元素 ```html <div class="wrapper" ref="wrapper"> <div class="content"> <!-- 内容 --> </div> </div> ``` 6. 完整代码示例 ```html <template> <div class="scroll-wrapper"> <div class="wrapper" ref="wrapper"> <div class="content"> <ul> <li v-for="item in list" :key="item.id">{{ item.title }}</li> </ul> </div> <div class="pullup-wrapper"> <div class="pullup"> <span v-show="!isPullUpLoad">上更多</span> <span v-show="isPullUpLoad">正在中...</span> </div> </div> </div> </div> </template> <script> import BScroll from 'better-scroll' export default { data() { return { list: [], // 列表数据 isPullUpLoad: false // 是否正在上 } }, mounted() { this.initScroll() }, methods: { initScroll() { this.scroll = new BScroll(this.$refs.wrapper, { probeType: 3, // 实时派发scroll事件 click: true, // 开启点击事件 pullDownRefresh: true, // 开启下刷新 pullUpLoad: true // 开启上 }) // 监听下刷新和上事件 this.scroll.on('pullingDown', () => { // 下刷新业务逻辑 this.scroll.finishPullDown() // 完成下刷新 this.scroll.refresh() // 重新计算滚动区域 }) this.scroll.on('pullingUp', () => { // 上业务逻辑 this.isPullUpLoad = true // 正在上 setTimeout(() => { this.isPullUpLoad = false // 完成上 this.scroll.finishPullUp() // 完成上 this.scroll.refresh() // 重新计算滚动区域 }, 1000) }) } } } </script> <style> .scroll-wrapper { height: 100%; overflow: hidden; } .wrapper { height: 100%; overflow: auto; } .pullup-wrapper { text-align: center; margin-top: 10px; margin-bottom: 10px; } .pullup { height: 40px; line-height: 40px; } </style> ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值