vue element使用el-table时,切换tab,table表格列项发生错位问题

展示问题

问题描述:使用el-table的fixed="right"属性后,如果切换tab时,回出现最后一列错误的问题

官网提供解决方法:doLayout

  • 需要注意的事项:我这里是通过组件使用的table组件,涉及多层组件封装问题,所以找这个根组件ref找到doLayout方法的时候需要注意写法 (如果存在组件签套,记得多加几次$refs[refName]调用方法)
js 复制代码
<el-tabs v-model="searchParam.activeName" @tab-click="handleClick">
  <el-tab-pane label="统计" name="first">
    <leftTable
      ref="leftTableRef"
      :table-data-list="gateStatisticsListTable"
      :table-all="gateStatisticsListTableAll"
      :count="tableDataCount"
      :search-param="searchParam"
      @refresh="refresh"
      @export-all="exportAll"
      @change-page="changePage" />
  </el-tab-pane>
  <el-tab-pane label="明细" name="second">
    <rightTable
      ref="rightTableRef"
      :table-data-list="gateStatisticsListTable"
      :table-all="gateStatisticsListTableAll"
      :count="tableDataCount"
      :search-param="searchParam"
      @refresh="refresh"
      @export-all="exportAll"
      @change-page="changePage" />
  </el-tab-pane>
</el-tabs>
js 复制代码
 handleClick(tab, event) {
   this.$nextTick(() => {
    if (this.searchParam.activeName === 'first') {
      const that = this
      // 其中leftTableRef是el-table的ref
      that.$refs.leftTableRef.$refs.tableRef.doLayout()
      // 切换 tab请求接口
      this.queryData()
    }
    if (this.searchParam.activeName === 'second') {
      // 其中rightTableRef是el-table的ref
      const that = this
      that.$refs.rightTableRef.$refs.tableRef.doLayout()
      // 切换 tab请求接口
      this.queryData()
    }
  })
},

修改后的效果展示:

相关推荐
白小白灬8 分钟前
Vue主题色切换实现方案(CSS 变量 + 类名切换)
前端·css·vue.js
江沉晚呤时13 分钟前
.NET Core 中 Swagger 配置详解:常用配置与实战技巧
前端·.netcore
waterHBO27 分钟前
chrome 浏览器插件 myTools, 日常小工具。
前端·chrome
哎呦你好29 分钟前
HTML 颜色全解析:从命名规则到 RGBA/HSL 值,附透明度设置与场景应用指南
前端·css·html
多云的夏天1 小时前
前端:VUE-(0)-环境搭建和helloworld
前端·javascript·vue.js
Dontla1 小时前
BootCDN介绍(Bootstrap主导的前端开源项目免费CDN加速服务)
前端·开源·bootstrap
90后小陈老师2 小时前
WebXR教学 07 项目5 贪吃蛇小游戏
前端·数码相机
一口一个橘子2 小时前
[ctfshow web入门] web118
前端·web安全·网络安全
GanGuaGua2 小时前
Vue3:脚手架
前端·javascript·css·vue.js·vue
weixin_431600442 小时前
使用 Vue Tour 封装一个统一的页面引导组件
javascript·vue.js·ecmascript