vue 3.2.6:用better-scroll实现上拉加载/下拉刷新/滚动翻页(better-scroll@2.4.2)

一,better-scroll的地址:

代码地址:
https://github.com/ustbhuangyi/better-scroll
在npm的地址:
https://www.npmjs.com/package/better-scroll

说明:刘宏缔的架构森林是一个专注架构的博客,

网站:https://blog.imgtouch.com
本文: https://blog.imgtouch.com/index.php/2023/05/28/vue-3-2-6-yong-betterscroll-shi-xian-shang-la-jia-zai-xia/

         对应的源码可以访问这里获取: https://github.com/liuhongdi/
         或: https://gitee.com/liuhongdi

说明:作者:刘宏缔 邮箱: 371125307@qq.com

 

二,安装better-scroll:

liuhongdi@lhdpc:/data/vue/storeweb$ npm install better-scroll -S
 
added 16 packages in 8s

三,编写代码

List.vue
<template>
  <div class="wrapper" style="width:100%;height:100%;background: #ffff00;">
    <div class="content">
       <div class="posi_ref" style="display: none;">
           <i class="el-icon-loading"></i>下拉刷新
       </div>
       <div>分类</div>
       <div>{{msg}}</div>
       <template v-for="(goodsOne,index) in listAll" :key="index">
          <router-link :to="{ path: '/list/detail', query: { goodsId: goodsOne.id }}">
             <div  style="height:120px;line-height:120px;">
                  {{ goodsOne.id }}
             </div>
          </router-link>
      </template>
    </div>
  </div>
</template>

<script>
import { ref,onMounted,reactive} from "vue";
import {apiGoodsList} from "../../api/api";
//引入better-scroll
import BScroll from 'better-scroll';
export default {
  name: "List",
  setup() {
    //当前是第几页,默认是第一页
    const curPage = ref(1);
    //保存用户数据的变量
    const msg = ref("");
    //better scroll
    let bscroll = reactive({});
    onMounted(() => {
             bscroll = new BScroll(document.querySelector('.wrapper'),{
               scrollY: true,
               probeType:3,
               click:true,
               //pullUpLoad:true,
               pullUpLoad:{
                  // 当上拉距离超过10px时触发 pullingUp 事件
                  threshold: -10
               },
               mouseWheel: true,
               pullDownRefresh:{
                 stop:0,
                 threshold:40
               },
             })
             bscroll.on("pullingUp",async ()=>{
               console.log('现在正在上拉加载更多...')
               await info();//请求数据
               bscroll.finishPullUp();//上拉加载动作结束,
               bscroll.refresh();//重新计算 BetterScroll
             })
            bscroll.on('pullingDown', async () => {
               console.log('处理下拉刷新操作')
              //设置当前页为第一页
              curPage.value = 1;
               //清空数组
              listAll.length = 0;
              await info();//请求数据
              bscroll.finishPullDown();//下拉加载动作结束
              bscroll.refresh();//重新计算 BetterScroll
           });
      //显示 下拉刷新
      bscroll.on("scroll",function(){
        if(this.y>10){
          document.querySelector('.posi_ref').style.display = "";
        }else{
          document.querySelector('.posi_ref').style.display = "none";
        }
      });
    });
    //保存页面数据的数组
    let listAll = reactive([]);

    //从接口获取用户信息
    const info = () => {
      apiGoodsList({
        p: curPage.value,
      }).then(res => {
        //成功
        if (res.code == 0) {
          //说明:此处我们从客户端添加数据仅供演示,正常情况应该从服务端api返回
          msg.value = res.data.msg;
          //第四页
          if (curPage.value == 4) {
            curPage.value = 5;
            return;
          }
          //第三页
          if (curPage.value == 3) {
            curPage.value = 4;
            let listOne = [{"id":21},{"id":22},{"id":23},{"id":24},{"id":25},
              {"id":26},{"id":27},{"id":28},{"id":29},{"id":30},];
            listAll.push(...listOne);
            console.log(listAll);
            return;
          }
          //第二页
          if (curPage.value == 2) {
            curPage.value = 3;
            let listOne = [{"id":11},{"id":12},{"id":13},{"id":14},{"id":15},
              {"id":16},{"id":17},{"id":18},{"id":19},{"id":20},];
            listAll.push(...listOne);
            console.log(listAll);
            return;
          }
          //第一页
          if (curPage.value == 1) {
            curPage.value = 2;
            //list.value = {1,2,3,4,5,6,7,8,9,10}
            let listOne = [{"id":1},{"id":2},{"id":3},{"id":4},{"id":5},
              {"id":6},{"id":7},{"id":8},{"id":9},{"id":10},];
            listAll.push(...listOne);
            console.log(listAll);
            return;
          }
        }
      }).catch((error) => {
        console.log(error)
      })
    };
    info();
    return {
      info,
      msg,
      listAll,
    };
  }
}

</script>

<style scoped>
.wrapper{
  overflow: hidden;
}
</style>

 

 
 

四,查看效果

五,查看better-scroll版本:

liuhongdi@lhdpc:/data/vue/storeweb$ npm list better-scroll
storeweb@0.1.0 /data/vue/storeweb
└── better-scroll@2.4.2
       查看vue.js的版本:
liuhongdi@lhdpc:/data/vue/storeweb$ npm list vue
storeweb@0.1.0 /data/vue/storeweb
├─┬ @vue/cli-plugin-babel@4.5.13
│ └─┬ @vue/babel-preset-app@4.5.13
│   └── vue@3.2.6 deduped
├─┬ element-plus@1.1.0-beta.7
│ └── vue@3.2.6 deduped
├─┬ vue-router@4.0.11
│ └── vue@3.2.6 deduped
└── vue@3.2.6 

 

posted @ 2021-09-23 16:22  刘宏缔的架构森林  阅读(2269)  评论(0编辑  收藏  举报