Element ui plus 中 table scroll 自动触底

Element ui plus 中 table scroll 自动触底

场景:添加客户等级的时候,新增的客户等级 input 框 被 scroll 遮挡、重叠,需要保证 scroll 保持在 最底部接可以解决 遮挡、重叠。

在这里插入图片描述

el-table 在设置了 height 后,会选择将 table 表头固定

<el-table :height="tableData.length*40+50>tableHeight?tableHeight:tableData.length*40+50" :data="tableData"
              style="width: 100%;"
              ref="TableRef"
              :cell-style="{ textAlign: 'center' }"
              v-loading="loading"
              :header-cell-style="{ 'text-align': 'center',background: '#f9f9f9', color: 'black',padding:'16px 0px'}"
    >
//table 中的其他内容
</el-table>

获取ta

### Element Plus 表格组件触底加载更多数据 为了实现在 `Element Plus` 的 `table` 组件中当滚动底部自动加载更多的数据,可以采用监听表格容器的滚动事件来检测是否到达底部,并在此基础上触发新的数据请求。 通过自定义指令的方式绑定到 `el-table` 上是一个有效的方法[^2]。具体来说,在 Vue 组件内创建一个名为 `loadmore` 的自定义指令用于处理这一逻辑: ```javascript // 定义 loadmore 自定义指令 app.directive('loadmore', { mounted(el, binding) { let timer; function handleScroll() { clearTimeout(timer); const wrapper = el.querySelector('.el-table__body-wrapper'); if (wrapper.scrollTop + wrapper.clientHeight >= wrapper.scrollHeight - 10 && !binding.value.loading) { binding.value.loadMore(); } timer = setTimeout(() => { window.removeEventListener('scroll', handleScroll); }, 100); } window.addEventListener('scroll', handleScroll); // 清除事件监听器防止内存泄漏 el componentWillUnmount() { window.removeEventListener('scroll', handleScroll); }; }, }); ``` 接着是在模板部分应用此指令并设置相应的属性给它传递方法以及状态变量: ```html <template> <div> <!-- 使用 v-loadmore 指令 --> <el-table :data="tableData" @row-click="handleRowClick" v-loadmore="{ loading, loadData }"> ... </el-table> <!-- 加载指示符 --> <p v-if="loading">正在加载...</p> </div> </template> ``` 其中 `loading` 是布尔类型的响应式属性用来控制加载过程中的显示;而 `loadData()` 则是用来发起新一批次的数据请求函数。每当用户滚动接近页面末端时就会调用该函数去获取额外的信息填充至现有列表之中。 另外需要注意的是,如果希望在每次更新视图之后能够立即获得最新的 DOM 结构变化情况(比如新增加了一些行),那么可以在适当的位置利用 `nextTick` 来确保操作发生在下次DOM 更新循环结束之后[^1]。 例如,在完成一次异步加载后想要重新测量某些元素尺寸的情况下就可以这样做: ```javascript this.$nextTick(() => { // 此处可执行依赖于最新渲染结果的操作 }) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值