elementUI表格tableixed=“right“ 导致固定列错位的解决方法

html 复制代码
<el-table ref="table" :data="crud.data" :height="tableHeight"  :header-cell-style="{ background :key="tableKey">
 <el-table-column
      prop="date"
      label="日期"
      width="150">
    </el-table-column>
    <el-table-column
      prop="name"
      label="姓名"
      width="120">
    </el-table-column>
    <el-table-column
      prop="province"
      label="省份"
      width="120">
    </el-table-column>
    <el-table-column
      prop="city"
      label="市区"
      width="120">
    </el-table-column>
    <el-table-column
      prop="address"
      label="地址"
      width="300">
    </el-table-column>
    <el-table-column
      prop="zip"
      label="邮编"
      width="120">
    </el-table-column>
     <el-table-column  label="操作"
     align="center" fixed="right"  width="168">
     </el-table-column>
  </el-table>

这里面增加了 :key="tableKey"

javascript 复制代码
<script>
  export default {
    data() {
      return {
        tableKey: 0,
        tableData: [{
          date: '2016-05-03',
          name: '王小虎',
          province: '上海',
          city: '普陀区',
          address: '上海市普陀区金沙江路 1518 弄',
          zip: 200333
        }, {
          date: '2016-05-02',
          name: '王小虎',
          province: '上海',
          city: '普陀区',
          address: '上海市普陀区金沙江路 1518 弄',
          zip: 200333
        }, {
          date: '2016-05-04',
          name: '王小虎',
          province: '上海',
          city: '普陀区',
          address: '上海市普陀区金沙江路 1518 弄',
          zip: 200333
        }, {
          date: '2016-05-01',
          name: '王小虎',
          province: '上海',
          city: '普陀区',
          address: '上海市普陀区金沙江路 1518 弄',
          zip: 200333
        }, {
          date: '2016-05-08',
          name: '王小虎',
          province: '上海',
          city: '普陀区',
          address: '上海市普陀区金沙江路 1518 弄',
          zip: 200333
        }, {
          date: '2016-05-06',
          name: '王小虎',
          province: '上海',
          city: '普陀区',
          address: '上海市普陀区金沙江路 1518 弄',
          zip: 200333
        }, {
          date: '2016-05-07',
          name: '王小虎',
          province: '上海',
          city: '普陀区',
          address: '上海市普陀区金沙江路 1518 弄',
          zip: 200333
        }]
      }
    },
​      // CRUD 钩子:数据刷新后重新计算表格布局(这是本人 你们可以试试的时候可以忽略)
  [CRUD.HOOK.afterRefresh]() {
    this.$nextTick(() => {
      if (this.$refs && this.$refs.table && this.$refs.table.doLayout) {
        this.$refs.table.doLayout();
      }
    });
  },
    watch: {
    // 当表格数据或其内部内容变化后,重新计算布局,避免固定列与主体错位
    'crud.data': {
      handler() {
        this.$nextTick(() => {
          if (this.$refs && this.$refs.table && this.$refs.table.doLayout) {
            this.$refs.table.doLayout();
          }
        });
      },
      deep: true
    },
    updated() {
        // 数据更新后重新计算表格布局,解决固定列错位问题
       this.$nextTick(() => {
          if (this.$refs.table) {
            this.$refs.table.doLayout();
          }
       });
    },

  }
</script>
css 复制代码
/* 解决 Element UI 表格 fixed 列错位问题 */
::v-deep .el-table__fixed,
::v-deep .el-table__fixed-right {
  height: 100% !important;
}

::v-deep .el-table__fixed-right-patch {
  background-color: #ecf2fd;
}

/* 确保表格内容不会溢出 */
::v-deep .el-table__body-wrapper {
  overflow-x: auto;
}

/* 固定列阴影优化 */
::v-deep .el-table__fixed-right::before {
  box-shadow: -1px 0 8px rgba(0, 0, 0, 0.1);
}

1. 添加表格强制刷新机制

  • el-table 上添加了 :key="tableKey" 属性(第257行)
  • 在 data 中添加了 tableKey: 0 用于强制重渲染

2. 添加数据变化监听

  • 已有的 watch 监听 crud.data 变化(第812-822行),数据变化时自动调用 doLayout()

3. 添加生命周期钩子

  • mounted 钩子中调用 doLayout()(第1239-1243行)
  • 新增 updated 钩子,在组件更新后重新计算布局(第1244-1252行)

4. 添加 CRUD 钩子(可以忽略)

  • 新增 [CRUD.HOOK.afterRefresh]() 钩子(第809-817行),在数据刷新后重新计算表格布局

5. 优化样式

  • 添加了针对固定列的样式修复(第3678-3698行):
    • 强制固定列高度为 100%
    • 优化固定列补丁背景色
    • 确保表格内容不溢出
    • 优化固定列阴影效果
相关推荐
LinXunFeng5 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
闪闪发亮的小星星10 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq10 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
阿米亚波10 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.10 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余10 天前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.10 天前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
秋波。未央10 天前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习
中屹指纹浏览器10 天前
2026指纹浏览器字体指纹、字体渲染偏差检测与全维度虚拟字体池搭建方案
经验分享·笔记