elementui el-table 表头固定功能

1. 功能目标

当用户向下滚动页面并进入明细数据表格区域时,表头固定在浏览器可视窗口顶部;当滚动位置离开表格区域或超过表格底部时,表头自动恢复到原位置。

  • 解决 Element UI 表格原生结构下 CSS sticky 不稳定的问题。
  • 只在视口顶部位于 el-table 范围内时固定表头。
  • 固定表头时保持宽度、左侧位置与表格一致,避免列错位。
  • 数据刷新、窗口尺寸变化时重新计算固定状态。

2. 实现总览

实现采用滚动事件 + DOM 边界判断 + fixed 样式切换。核心流程如下:

  • mounted 中注册 resize 和 scroll 监听。
  • getBiTableElements 获取表格、表头和表体 DOM。
  • updateBiTableHeaderFixed 判断是否需要固定表头。
  • resetBiTableHeaderFixed 在离开表格区域时清除固定状态。
  • beforeDestroy 中解绑事件并清理固定样式。

3. 关键代码片段

滚动监听与生命周期清理

javascript 复制代码
mounted() {
  window.addEventListener('resize', this.resizeCharts);
  window.addEventListener('scroll', this.updateBiTableHeaderFixed, true);
  this.$nextTick(() => {
    this.updateBiTableHeaderFixed();
  });
},
beforeDestroy() {
  window.removeEventListener('resize', this.resizeCharts);
  window.removeEventListener('scroll', this.updateBiTableHeaderFixed, true);
  this.resetBiTableHeaderFixed();
}

表格元素获取

javascript 复制代码
getBiTableElements() {
  const table = this.$el && this.$el.querySelector('.bi-table.el-table');
  if (!table) {
    return {};
  }
  return {
    table,
    header: table.querySelector('.el-table__header-wrapper'),
    body: table.querySelector('.el-table__body-wrapper')
  };
}

固定和释放判断

javascript 复制代码
updateBiTableHeaderFixed() {
  const { table, header, body } = this.getBiTableElements();
  if (!table || !header || !body) {
    return;
  }

  const tableRect = table.getBoundingClientRect();
  const headerHeight = header.offsetHeight || 0;
  const shouldFix = tableRect.top <= 0 && tableRect.bottom > headerHeight;

  if (!shouldFix) {
    this.resetBiTableHeaderFixed();
    return;
  }

  header.classList.add('bi-table-header-fixed');
  header.style.left = tableRect.left + 'px';
  header.style.top = '0px';
  header.style.width = tableRect.width + 'px';
  body.style.paddingTop = headerHeight + 'px';
}

固定表头样式

css 复制代码
.bi-page .bi-table .el-table__header-wrapper.bi-table-header-fixed {
  position: fixed;
  z-index: 2000;
  overflow: hidden;
}
相关推荐
YiWait1 小时前
基于 Vue 3 的网络收音机,编译为桌面应用软件
前端·javascript·vue.js
古法编程第一人1 小时前
使用Electric同步前后端数据
前端·vue.js
Fisschl1 小时前
在 Vue 中实现输入框@人功能
vue.js
大连好光景1 小时前
登录凭证 | Session+Cookie | Redis Token | JWT
前端·javascript
英俊潇洒美少年2 小时前
Vue 生产环境打包:SourceMap、压缩、混淆、Gzip、多环境配置 企业级最佳实践
前端·javascript·vue.js
MXN_小南学前端2 小时前
Vue 后台管理系统:封装通用el-table导出方法(附完整源码)
javascript·vue.js
一 乐2 小时前
公交线路查询系统|基于Java+vue公交线路查询系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·公交线路查询系统
i220818 Faiz Ul2 小时前
相亲网站|相亲网站系统|基于Java+vue相亲网站系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·相亲网站系统
xwjalyf3 小时前
javascript数组 forEach,filter,some,every,map,find,reduce的用法与区别
开发语言·javascript·json·ecmascript