element ui中Timeline时间线结合InfiniteScroll 无限滚动展示数据

该代码片段展示了一个使用Vue.js和ElementUI库创建的时间线组件,具有无限滚动功能。当用户滚动到底部时,通过axios获取更多数据并更新dataList,实现动态加载。同时,实现了分页功能,根据总条数和每页显示数量计算总页数。
摘要由CSDN通过智能技术生成
<template>
  <div>
      <el-timeline
        v-infinite-scroll="load"
        style="overflow: auto">
        <el-timeline-item :timestamp="item.craeteDate" placement="top" v-for="(item,index) in dataList" :key="index">
          <el-card>
            <h4>{{item.title}}</h4>
            <p>{{item.content}}</p>
          </el-card>
        </el-timeline-item>
      </el-timeline>
      <div style="font-size: 16px;
            color: #666666;
            margin-bottom: 30px;
            text-align: center;">
        暂无数据
      </div>
  </div>
</template>

<script>
export default {
  name: 'wel',
  data() {
    return {
      finish: false,
      dataList:[],
      page: {
        total: 0, // 总条数
        current: 1,// 当前页数,
        size: 10 // 每页显示多少条
      }
    }
  },
  created() {
    this.getDataList()
  },
  methods:{
    getDataList() {
      getDataList(this.page).then(response => {
        this.dataList= this.dataList.concat(response.data.data.records);
        this.page.total = response.data.data.total;
      }).catch((e) => {

      });
    },
    load() {
      //延迟1s执行 保证getDataList执行完毕 能取到总条数
      setTimeout(()=>{
        this.page.current=this.page.current+1;
        let totalPage = Math.ceil(this.page.total / this.page.size);
        if (this.page.current > totalPage) {
          if (this.dataList.length == 0) {
            this.finish = false;
          } else {
            this.finish = true;
          }
          return;
        } else {
          this.finish = false;
        }
        this.getDataList();
      },1000)
    }
  }
}

</script>

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 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-timelineel-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-timelinescroll 事件,将 el-timelinescrollTop 设置为最大值,让其自动滚动到底部。代码如下: ```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、付费专栏及课程。

余额充值