vue3——自己实现数据无限加载功能的封装

44 篇文章 0 订阅
14 篇文章 0 订阅

vue3——自己实现数据无限加载功能的封装

一、封装的意义

  • 数据较多的时候,滑动滚动条显示加载状态,可以给用户很好的体验
  • 代码维护性更好
  • 代码可复用

二、如何封装?

需要用到@vueuse/core中的useIntersectionObserver,用来判断元素是否出现在可视区
链接:useIntersectionObserver

1. 准备

项目根目录下打开任意终端,执行npm install @vueuse/core@5.3.0,这里安装的固定版本,各位按需选择

因考虑复用组件,故封装为全局组件,老套路src/components下新建infinite-loading.vue文件
代码如下:

<template>
  <div class="infinite-loading" ref="container">
    <div class="loading" v-if="loading">
      <span class="img"></span>
      <span class="text">正在加载中...</span>
    </div>
    <div class="none" v-if="finished">
      <span class="img"></span>
      <span class="text">亲,没有更多了</span>
    </div>
  </div>
</template>

<script>
import { ref } from 'vue'
import { useIntersectionObserver } from '@vueuse/core'
export default {
  name: 'InfiniteLoading',
  props: {
    loading: {
      type: Boolean,
      default: false
    },
    finished: {
      type: Boolean,
      default: false
    }
  },
  setup (props, { emit }) {
    const container = ref(null)
    useIntersectionObserver(
      container,
      ([{ isIntersecting }], dom) => {
        if (isIntersecting) {
          // 当loading和finished的值都为false时,就通知父组件调用方法继续向后台请求数据
          if (props.loading === false && props.finished === false) {
            emit('infinite')
          }
        }
      },
      {
        threshold: 0
      }
    )
    return { container }
  }
}
</script>

<style scoped lang='less'>
.infinite-loading {
  .loading {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 200px;
    .img {
      width: 200px;
      height: 200px;
      background: url(https://code-1307161657.cos.ap-beijing.myqcloud.com/images%2Fload.gif) no-repeat center / contain;
    }
    .text {
      color: #999;
      font-size: 16px;
    }
  }
  .none {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 200px;
    .img {
      width: 200px;
      height: 134px;
      background: url(https://code-1307161657.cos.ap-beijing.myqcloud.com/images%2Fnone.png) no-repeat center / contain;
    }
    .text {
      color: #999;
      font-size: 16px;
    }
  }
}
</style>

可以直接在要使用的组件中,注册一下。也可看之前文章,使用vue插件的方式注册为全局组件,这里就不演示了~

2. 使用

在任意.vue结尾文件中使用

代码如下(示例):
代码中注释为书写思路,改为接口方法向后台发送请求即可

<template>
 <div class="home-container">
   <InfiniteLoading :loading="loading" :finished="finished" @infinite="getData"/>
 </div>
</template>

<script>
import { ref } from 'vue'
export default {
  name: 'App',
  setup () {
    const loading = ref(true)
    const finished = ref(true)

    const getData = () => {
      // 开始向后台请求数据,loading的值设置为true
      // 表示开始请求数据,显示加载中的样式
      // loading.value = true

      // 当本次调用结束后,将loading的值设置为false,表示本次结束
      // loading.value = false
      // 将页码++

      // 当所有数据加载完毕,将finished的值设置为true
      // finished.value = true
      // 表示所有数据加载完毕,显示加载已完毕的样式
    }

    return { loading, finished, getData }
  }

}
</script>

<style lang="less">
.home-container {
  margin: 100px auto;
  width: 1000px;
  height: 500px;
}
</style>

三、 效果演示

加载中效果
在这里插入图片描述
加载完毕效果
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,我可以为您提供关于使用vue-infinite-loading实现php无限加载的一些指导。 首先,您需要安装vue-infinite-loading。可以通过npm或yarn安装,具体操作为: ``` npm install vue-infinite-loading --save ``` 或 ``` yarn add vue-infinite-loading ``` 安装完成后,在您的Vue组件中引入该组件: ```javascript import InfiniteLoading from 'vue-infinite-loading'; export default { components: { InfiniteLoading, }, }; ``` 接下来,您需要在组件的template中使用该组件,并在data中定义需要加载数据列表和当前页码: ```html <template> <div> <ul> <li v-for="item in list" :key="item.id">{{ item.title }}</li> </ul> <infinite-loading @infinite="infiniteHandler"></infinite-loading> </div> </template> <script> export default { data() { return { list: [], page: 1, }; }, methods: { infiniteHandler($state) { // 这里使用ajax请求获取数据,page为当前页码 axios.get('/api/list', { params: { page: this.page, }, }).then((res) => { if (res.data.length > 0) { this.list = this.list.concat(res.data); this.page += 1; $state.loaded(); } else { $state.complete(); } }); }, }, }; </script> ``` 在上面的代码中,我们使用axios发送ajax请求获取数据,并在请求成功后使用concat方法将新数据追加到原数据列表中。同时,我们使用$state.loaded()方法告诉vue-infinite-loading组件数据已经加载完毕,可以继续加载下一页数据。如果返回的数据为空,则使用$state.complete()方法告诉vue-infinite-loading组件数据已经全部加载完毕。 最后,您需要在样式中设置vue-infinite-loading组件的高度和样式: ```css .vue-infinite-loading { height: 60px; line-height: 60px; text-align: center; } ``` 这样就完成了使用vue-infinite-loading实现php无限加载的操作。希望以上内容能够对您有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值