【el-table滚动事件】el-table表格滚动时,获取可视窗口内的行数据

一个简单的获取内容的办法
表格部分,主要是ref写一下

javascript 复制代码
 <el-table :data="tableData" ref="tableRef"> </el-table>

进入页面的时候绑定监听

javascript 复制代码
mounted(){
// 绑定滚动事件
                this.$nextTick(() => {
                    const table = this.$refs.tableRef;
                    const scrollBody = table.$el.querySelector(".el-table__body-wrapper");

                    // 1. 手动绑定滚动事件
                    scrollBody.addEventListener("scroll", this.fangdou);

                    // 2. 初始计算一次可视行
                    this.fangdou();

                    // 3. 监听窗口变化(可选)
                    window.addEventListener("resize", this.fangdou);
                });
}

函数部分,增加了一层防抖。滚动停止再执行,不然执行的太频繁了

逻辑就是算出可视区域的高度,然后行要固定高,每行的高度你算一下或者写个固定的多少,这样就可以通过可视高度/行高得到,目前一次能拿到多少条。然后通过滚动条到顶部的位置距离,算出已经滚动过去多少个了,最后算出来的数量在表格内数组里抽数据

javascript 复制代码
methods(){
				fangdou(e) {
                    // 清除之前的定时器
                    if (this.scrollTimer) clearTimeout(this.scrollTimer);
                    // 设置新的定时器(延迟500ms执行)
                    this.scrollTimer = setTimeout(() => {
                        this.handleScroll();
                    }, 500);
                },
                handleScroll() {
                    const table = this.$refs.tableRef;
                    const scrollBody = table.$el.querySelector(".el-table__body-wrapper");

                    // 获取滚动位置和可视区域高度
                    const scrollTop = scrollBody.scrollTop;
                    const visibleHeight = scrollBody.clientHeight;
                    // 计算起始行和结束行索引
                    const startIndex = Math.floor(scrollTop / 50);
                    const endIndex = Math.min(startIndex + Math.ceil(visibleHeight / 50), this.tableData.length - 1);
                    // 获取可视行数据
                    const visibleRows = this.tableData.slice(startIndex, endIndex);
                    this.wdArr = [];
                    visibleRows.forEach((item) => {
                        // 未读状态,并有考核的数据才查看是否已读
                        if (item.is_read !== 1 && item.khf) {
                            this.wdArr.push(item.id);
                        }
                    });
                    // 这里写你要做的事
                    if (this.wdArr.length > 0) {
                        this.edit_read();
                    }
                },
}
相关推荐
anOnion1 天前
Agentic 前端开发之 实时显示 AI Agent 终端输出
前端·javascript·人工智能
这是个栗子1 天前
【前端性能优化】优化数据加载:用 Promise.all 从串行到并行
前端·javascript·性能优化·异步编程·前端优化·promise.all
fei_sun1 天前
黑洞路由(Null Route/空接口路由)
服务器·前端·javascript
格子软件1 天前
2026年GEO优化系统源码的分布式状态机深度拆解
java·前端·vue.js·vue·geo
摇滚侠1 天前
方法 A 等方法 B 执行完再执行 叫同步调用还是异步调用 JS 默认是同步调用还是异步调用
开发语言·javascript·ecmascript
格子软件1 天前
2026年GEO优化系统源码解构:核心状态机与高并发流控深度剖析
java·vue.js·spring boot·vue·geo
触底反弹1 天前
🔥 字符串算法面试三连击:反转、回文、回文变种,搞懂这三题稳了!
前端·javascript·算法
触底反弹1 天前
AI Tool Use 深度解析:大模型是如何"突破物理限制"调用外部工具的?
javascript·人工智能·后端
程序边界1 天前
lac_agent自愈链路下篇——从systemd托管到真正的自愈
前端·javascript·chrome
竹林8181 天前
从 RPC 超时到批量签名:我用 @solana/web3.js 重构了一个 NFT 铸造页面,踩了这些坑
前端·javascript