[Vue+Element UI] v-infinite-scroll 无限滚动使用总结

本文介绍了如何在基于Vue2的项目中使用ElementPlus的无限滚动组件,并详细展示了列表的实现、loading和nomore提示的处理以及结合tab页切换的注意事项。
摘要由CSDN通过智能技术生成

官方文档

虽然无限滚动组件是 element plus 的组件, 而 element plus 适用于 Vue3, 但亲测同样适用于 Vue2.

请添加图片描述

// 1. 列表的外层容器添加无限滚动相关属性
     <div
       class="workbench-agenda-content"
       v-infinite-scroll="onLazyLoad"
       infinite-scroll-disabled="disabled"
       infinite-scroll-immediate="false"
     >
       <span id="empty-tip" style="margin-top: 10px">暂无数据</span>
       <agenda-list-item
         v-for="item of agendaList"
         :key="item.id"
         :type="agendaType"
         :item="item"
       />
// 2. 添加 loading 和 no more 场景提示
       <p v-if="listParams.loading">Loading...</p>
       <p v-if="listParams.finished">No More</p>
     </div>

// 3. 列表和列表参数
	  data() {
	    return {
	      agendaList: [],
	      listParams: {
	        pageNo: 1,
	        pageSize: 4,
	        loading: false,
	        error: false,
	        finished: false,
	      },
	   }
	}

// 4. 列表请求方法
    queryList() {
     const params = {
        pageSize: this.listParams.pageSize,
        pageNo: this.listParams.pageNo,
      }
      api.xxx.then((res) => {
       // 空数据处理
        if (!res || !res.length) {
          this.listParams.loading = false
          this.listParams.finished = true
          return
        }
       // 拼接数据
       this.agendaList = this.agendaList.concat(res)
       // 关闭 loading
       this.listParams.loading = false
       // 若返回条目小于设定的每页条目, 则显示 no more
       if (res.length < this.listParams.pageSize) {
         this.listParams.finished = true
       } 
    })
 // 5. 懒加载(在滚动到容器最底部时触发)
    onLazyLoad() {
      this.listParams.loading = true
      if (this.listParams.finished == false) {
      // 加载未结束, 则增加分页参数
        this.listParams.pageNo++
        // 请求列表数据
        this.queryApplyListForWorkbench(this.agendaType)
      }
    },
},

注:
pageSize 设置要超过当前页面显示数据量, 滚动功能才不会出bug

若结合tab页使用, 注意要在切换回调事件里清空数据并重置参数, 再请求数据

    // 待办已办页签切换回调
    handleAgendaClick(index) {
      this.agendaType = index
      // 重置列表数据
      this.agendaList = []
      this.listParams = {
        pageNo: 1,
        pageSize: 4,
        loading: false,
        error: false,
        finished: false,
      }
      this.queryApplyListForWorkbench(this.agendaType)
    },
  • 7
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,让我们来一步步实现这个功能。 首先,我们需要安装 Element UI,可以通过 npm 安装: ``` npm install element-ui --save ``` 然后在 main.js 中引入并使用: ```js import Vue from 'vue' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' Vue.use(ElementUI) ``` 接下来,我们来实现时间线组件。可以在组件中使用 el-timeline 和 el-timeline-item 组件,代码如下: ```html <template> <el-timeline> <el-timeline-item v-for="(item,index) in list" :key="index" :timestamp="item.time">{{ item.content }}</el-timeline-item> </el-timeline> </template> ``` 其中,list 是传入组件的数据,包含每个时间点的内容和时间信息。 接着,我们来实现自动滚动功能。可以通过监听 el-timeline 的 scroll 事件,将 el-timeline 的 scrollTop 设置为最大值,让其自动滚动到底部。代码如下: ```html <template> <el-timeline ref="timeline" @scroll="handleScroll"> <el-timeline-item v-for="(item,index) in list" :key="index" :timestamp="item.time">{{ item.content }}</el-timeline-item> </el-timeline> </template> <script> export default { methods: { handleScroll() { const timelineEl = this.$refs.timeline.$el timelineEl.scrollTop = timelineEl.scrollHeight } } } </script> ``` 然后,我们来实现无限滚动和动态加载功能。可以使用 v-infinite-scroll 插件,通过监听 el-timeline 的滚动事件,在滚动到底部时触发加载更多数据的方法。代码如下: ```html <template> <el-timeline ref="timeline" @scroll="handleScroll" v-infinite-scroll="loadMore" infinite-scroll-disabled="loading" infinite-scroll-distance="10"> <el-timeline-item v-for="(item,index) in list" :key="index" :timestamp="item.time">{{ item.content }}</el-timeline-item> <div v-if="loading">正在加载...</div> </el-timeline> </template> <script> import { InfiniteScroll } from 'element-ui' export default { directives: { InfiniteScroll }, data() { return { list: [], // 数据列表 loading: false // 是否正在加载 } }, methods: { // 加载数据 loadMore() { if (this.loading) { return } this.loading = true // 模拟异步加载数据 setTimeout(() => { const newData = [{ time: '2021-08-01', content: '新的内容' }] this.list = this.list.concat(newData) this.loading = false }, 1000) }, // 滚动事件 handleScroll() { const timelineEl = this.$refs.timeline.$el if (timelineEl.scrollTop === 0) { this.loadMore() } } } } </script> ``` 在上面的代码中,我们使用element-ui 中的 InfiniteScroll 指令来实现无限滚动功能。同时,我们在 el-timeline 中添加了 infinite-scroll-disabled 和 infinite-scroll-distance 属性,分别用于控制是否禁用无限滚动和触发加载更多数据的距离。 现在我们已经完成了 element-ui 的时间线组件 + 自动滚动 + v-infinite-scroll 无限滚动 + 动态加载功能的实现。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值