news 2026/7/2 1:38:17

Vue2 中 v-if / v-else-if + el-table 组件复用坑问题总结

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue2 中 v-if / v-else-if + el-table 组件复用坑问题总结

1. 问题背景

vue2项目中,写法如下:

<divv-if="priceType ==='FIXED_PRICE'"><el-table:data="fixedRules"/></div><divv-else-if="priceType ==='RANGE_FIXED_PRICE'"><el-table:data="intervalFixedRules"/></div><divv-else-if="priceType ==='RANGE_MAX_PRICE'"><el-table:data="intervalMaxRules"/></div>

在切换 priceType 时,出现以下异常现象:

  1. 表头错乱 / 不刷新
  2. 数据显示串表
  3. 列结构残留
  4. 滚动条异常

数据本身是正确的,但UI显示不正确

2. 问题原因

  • 在vue2中,v-if / v-else-if组件复用机制

    • 在vue2中,同一层级下的v-if / v-else-if / v-else 会复用同一个组件实例。
  • el-table组件内部维护了大量状态:

    • columns配置缓存。
    • 表头结构
    • 行列计算结果
    • 滚动容器状态
    • 布局测量结果

所以,当DOM结构相似,只是字段含义不同时,vue判断其为‘高度可复用组件’,且el-table内部状态无法自动清理

3. 处理方案

为每个el-talbe设置唯一key

<divv-if="priceType ==='FIXED_PRICE'"><el-table:data="fixedRules"key="FIXED_PRICE"/></div><divv-else-if="priceType ==='RANGE_FIXED_PRICE'"><el-table:data="intervalFixedRules"key="RANGE_FIXED_PRICE"/></div><divv-else-if="priceType ==='RANGE_MAX_PRICE'"><el-table:data="intervalMaxRules"key="RANGE_MAX_PRICE"/></div>
  • 说明
    key不同,vue会强制销毁并重建组件,这个时候el-table内部状态会重置,priceType变化时,表格也会显示正常
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/29 18:49:47

比手动检测快10倍!自动化D3D11兼容性检查方案

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个自动化D3D11兼容性检查脚本&#xff0c;功能包括&#xff1a;1) 一键检测系统GPU规格&#xff1b;2) 与D3D11要求自动对比&#xff1b;3) 批量测试多台设备&#xff1b;4) …

作者头像 李华
网站建设 2026/6/30 2:49:16

Flutter Native Splash:打造完美启动体验的终极指南

Flutter Native Splash&#xff1a;打造完美启动体验的终极指南 【免费下载链接】flutter_native_splash Automatically generates native code for adding splash screens in Android and iOS. Customize with specific platform, background color and splash image. 项目地…

作者头像 李华
网站建设 2026/7/2 1:21:39

AI如何帮你自动生成Git提交关系图?

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个能够分析Git仓库提交历史的工具&#xff0c;自动生成可视化的提交关系图。要求&#xff1a;1. 支持本地仓库和远程仓库URL输入 2. 使用类似git log --graph的图形化展示 3.…

作者头像 李华
网站建设 2026/6/29 3:29:16

EVCapture在教育直播中的5个高效应用场景

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个专门针对教育场景优化的屏幕录制工具&#xff0c;需要&#xff1a;1.支持PPT演示讲师摄像头画中画录制 2.自动生成带时间戳的课程目录 3.内置激光笔和高亮标注工具 4.可导出…

作者头像 李华
网站建设 2026/6/28 22:10:39

第三方CNAS软件测试单位:【Gatling高级关联技术中的嵌套JSON、动态数组和上下文相关参数处理】

使用Gatling进行软件性能测试&#xff0c;高级关联技术是处理现代RESTful API和复杂应用场景的重要技能。当响应中包含嵌套JSON、动态数组或参数依赖前序上下文时&#xff0c;能否精准地提取并传递这些动态值&#xff0c;决定了测试脚本的可靠性和真实性。 为何需要高级关联&am…

作者头像 李华
网站建设 2026/7/1 18:37:20

Kotaemon病理报告分析:癌症筛查辅助阅读

Kotaemon病理报告分析&#xff1a;癌症筛查辅助阅读在乳腺癌、肺癌等重大疾病的诊疗过程中&#xff0c;一份病理报告往往决定了患者的整个治疗路径。然而&#xff0c;面对动辄上千字、术语密集且书写风格各异的病理文本&#xff0c;即便是经验丰富的病理科医生&#xff0c;也需…

作者头像 李华