el-table 表格从下往上滚动,触底自动请求新数据

关键点:

1、 el-table 需要设置高度 height;

2、el-table 外层盒子需要设置一个高度,并且设置 overflow:hidden;

3、获取 el-table 的 bodyWrapper:divData

divData.scrollTop + divData.clientHeight + 1 >= divData.scrollHeight;(触底)

重新请求数据;并将列表置顶:设置 divData.scrollTop = 0;

4、为el-table 添加鼠标移入移除事件,启停滚动;

javascript 复制代码
<!--
 * @Author: xxx
 * @objectDescription: 滚动、合并行table
 * @Date: 2024-04-16 14:35:58
-->
<template>
  <div class="span-roll-table">
    <div class="table-contain">
      <el-table
        ref="rollTable"
        :data="list"
        height="100%"
        :span-method="objectSpanMethod"
        :header-cell-style="{
          textAlign: 'center',
          width: 'fit-content',
          backgroundColor: '#F2F6FC',
        }"
        class="table"
        @mouseenter.native="stopScroll"
        @mouseleave.native="startScroll"
      >
      </el-table>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      list: [],
      rollTimer: null,
    };
  },
  mounted() {
    this.startScroll();
  },
  methods: {
    // 获取新数据
    async onChange() {
      this.list = [
        {
          name: "1",
        },
        {
          name: "2",
        },
        {
          name: "3",
        },
        {
          name: "4",
        },
      ];

      // 将列表置顶
      this.$nextTick(() => {
        const table = this.$refs.rollTable;
        const divData = table.bodyWrapper;
        divData.scrollTop = 0;
      });
    },
    // 开始滚动
    startScroll() {
      this.tableScroll(false);
    },
    // 停止滚动
    stopScroll() {
      this.tableScroll(true);
    },
    // 列表滚动
    tableScroll(stop) {
      if (stop) {
        if (this.rollTimer) {
          clearInterval(this.rollTimer);
          return;
        }
      }
      const table = this.$refs.rollTable;
      const divData = table.bodyWrapper;
      this.rollTimer = setInterval(() => {
        divData.scrollTop += 2;
        this.$nextTick(() => {
          if (
            divData.scrollTop + divData.clientHeight + 1 >=
            divData.scrollHeight
          ) {
            this.onChange();
          }
        });
      }, 200);
    },
    // 合并列表第一个单元格(并列排名)
    objectSpanMethod({ row, column, rowIndex, columnIndex }) {
      if (columnIndex === 0) {
        // 获取当前单元格的值(单元格项一定要配置 prop 属性,否则拿不到值!!!!)
        const currentValue = row[column.property];
        // 获取上一行相同列的值
        const preRow = this.typeTableData[rowIndex - 1];
        const preValue = preRow ? preRow[column.property] : null;
        // 如果当前值和上一行的值相同,则将当前单元格隐藏
        if (currentValue === preValue) {
          return { rowspan: 0, colspan: 0 };
        } else {
          // 否则计算当前单元格应该跨越多少行
          let rowspan = 1;
          for (let i = rowIndex + 1; i < this.typeTableData.length; i++) {
            const nextRow = this.typeTableData[i];
            const nextValue = nextRow[column.property];
            if (nextValue === currentValue) {
              rowspan++;
            } else {
              break;
            }
          }
          return { rowspan, colspan: 1 };
        }
      }
    },
  },
  beforeDestroy() {
    clearInterval(this.rollTimer);
    this.startScroll = () => {};
  },
};
</script>
<style lang="less" scoped>
.span-roll-table {
  height: 400px;

  .table-contain {
    height: 100%;
    overflow: hidden;
  }
}

/* 隐藏滚动条,但仍然可以滚动 */
::v-deep .el-table__body-wrapper::-webkit-scrollbar {
  display: none; /* 针对Webkit浏览器 */
}
</style>

参考文章

相关推荐
kgduu1 小时前
js之客户端存储
javascript·数据库·oracle
四千岁1 小时前
2026 最新版:WSL + Ubuntu 全栈开发环境,一篇搞定!
javascript·node.js
竹林8181 小时前
从“连接失败”到丝滑登录:我用 ethers.js 连接 MetaMask 的完整踩坑实录
前端·javascript
神舟之光1 小时前
jwt权限控制简单总结(乡村意见簿-vue-express-mongdb)
前端·vue.js·express
铭毅天下2 小时前
EasySearch Rules 规则语法速查手册
开发语言·前端·javascript·ecmascript
bjzhang752 小时前
使用 HTML + JavaScript 实现 SQL 智能补全功能
javascript·html·sql智能补全
流光墨佰2 小时前
我做了一个专为油猴打造的轻量级 Vue 组件注入库
vue.js
全栈前端老曹3 小时前
【前端地图】地图开发基础概念——地图服务类型(矢量图、卫星图、地形图)、WGS84 / GCJ-02 / BD09 坐标系、地图 SDK 简介
前端·javascript·地图·wgs84·gcj-02·bd09·地图sdk
Fairy要carry3 小时前
项目01-手搓Agent之loop
前端·javascript·python
kyriewen4 小时前
DOM树与节点操作:用JS给网页“动手术”
前端·javascript·面试