ElementUI表格错位修复技巧

问题 如图

点击勾选右侧字段 显示/隐藏,会导致左侧出现表格样式错乱问题

分析

分析问题:列显示/隐藏后,Element UI 表格未重新计算布局,导致样式错乱。修复 CRUD.operation.vue 中的 updateColumnVisible ,在列变更后强制表格重新布局。

解决方法

关键代码

javascript 复制代码
   // 强制表格重新计算布局,修复列显示/隐藏后的样式错乱问题
        this.$nextTick(() => {
          if (table && typeof table.doLayout === 'function') {
            table.doLayout();
          }
        });
      

使用了doLayout方法之后,基本就可以解决常见的错位问题了,如果情况特殊$nextTick不起作用,用setTimeout试一下即可。

修改后直接更新,让现场人员测试,结果! 发现了一个很奇葩的问题

奇葩错位

在el-tabs里已经doLayout处理过的table,在右边勾选 字段显示/隐藏,当表格只剩下2-3个字段的时候,又错位了。

现象

库位这一列,数据一行展示的时候,左侧会出现错位现象

库位这一列,数据多行展示的时候,不会出现错位现象

思考

在动态控制字段显示/隐藏的监听事件里再执行一次doLayout不就完了么,现实是,无效果。还是没有解决问题

经过多方面的测试,最终发现罪魁祸首就是

html 复制代码
<el-table-column 
prop="posName" 
:sortable="true" 
:label="$t('NeoLight.storageNo')" 
width="100" />

里边的这个**width**值!

解决el-table里所有错位问题的方法,其实就是,使用min-width ,根据label值的长度调整min-width,min-width过小就会导致各种奇葩的错位,例如上边这个库位的label,width="100"就会出现错位现象,设为min-width:100就没有问题了。

html 复制代码
<el-table-column 
prop="posName" 
:sortable="true" 
:label="$t('NeoLight.storageNo')"
 min-width="100" />

总结

根据表头文字长度、给有min-width的列设置合适的值,错位问题就解决了。

相关推荐
Mr_chiu7 分钟前
AI加持的交互革新:手把手教你用Vue3打造智能模板输入框
前端
精神状态良好9 分钟前
告别聊天式编程:引入 OpenSpec,构建结构化的 AI 开发工作流
前端
WangHappy12 分钟前
出海不愁!用Vue3 + Node.js + Stripe实现全球支付
前端·node.js
林希_Rachel_傻希希16 分钟前
手写Promise最终版本
前端·javascript·面试
visnix18 分钟前
AI大模型-LLM原理剖析到训练微调实战(第二部分:大模型核心原理与Transformer架构)
前端·llm
老妪力虽衰20 分钟前
零基础的小白也能通过AI搭建自己的网页应用
前端
褪色的笔记簿23 分钟前
在 Vue 项目里管理弹窗组件:用 ref 还是用 props?
前端·vue.js
Danny_FD24 分钟前
使用Taro实现微信小程序仪表盘:使用canvas实现仪表盘(有仪表盘背景,也可以用于Web等)
前端·taro·canvas
掘金安东尼33 分钟前
VSCode V1.107 发布(2025 年 11 月)
前端·visual studio code
一只小阿乐36 分钟前
前端vue3 web端中实现拖拽功能实现列表排序
前端·vue.js·elementui·vue3·前端拖拽