Vue:使用v-if v-else加载两个el-table 在切换时,会出现数据在家混乱 数据加载不全的情况

目录

  • [一、 出现场景](#一、 出现场景)
  • [二、 出现原因](#二、 出现原因)
  • 三、解决方案

一、 出现场景

使用v-if v-else加载两个el-table 在切换时,会出现数据在家混乱 数据加载不全的情况

二、 出现原因

  • Vue的虚拟DOM复用机制:v-if/v-else 切换时,Vue 会尝试复用相同标签的 DOM 元素来提升性能,导致 el-table 的实例没有被完全重新初始化。
  • el-table 内部的数据渲染异步性:表格的列、数据渲染是异步的,复用 DOM 后表格的状态没有被重置,从而出现数据混乱。

三、解决方案

给两个表格添加唯一的 key 属性:通过给每个 el-table 设置唯一的 key,告诉 Vue 这是两个不同的元素,不要复用它们的 DOM,从而让表格每次切换时都重新渲染,避免数据混乱。

html 复制代码
<template>
  <div>
    <!-- 切换按钮 -->
    <el-button @click="toggleTable">切换表格</el-button>

    <!-- 表格1:添加唯一key -->
    <el-table
      v-if="showTable1"
      :key="'table1'"  <!-- 唯一key -->
      :data="tableData1"
      border
      style="width: 100%; margin-bottom: 20px;"
    >
      <el-table-column prop="name" label="姓名" />
      <el-table-column prop="age" label="年龄" />
    </el-table>

    <!-- 表格2:添加唯一key -->
    <el-table
      v-else
      :key="'table2'"  <!-- 唯一key -->
      :data="tableData2"
      border
      style="width: 100%;"
    >
      <el-table-column prop="id" label="编号" />
      <el-table-column prop="product" label="产品名称" />
    </el-table>
  </div>
</template>

<script>
export default {
  data() {
    return {
      showTable1: true, // 表格切换标识
      // 表格1数据
      tableData1: [
        { name: '张三', age: 20 },
        { name: '李四', age: 22 },
        { name: '王五', age: 25 }
      ],
      // 表格2数据
      tableData2: [
        { id: 1, product: '手机' },
        { id: 2, product: '电脑' },
        { id: 3, product: '平板' }
      ]
    };
  },
  methods: {
    toggleTable() {
      this.showTable1 = !this.showTable1;
    }
  }
};
</script>
相关推荐
南知意-1 小时前
一个基于 Vue、Datav、Echart 框架开源免费的数据大屏可视化系统
前端·javascript·vue.js·开源软件·大屏项目
Dwzun1 小时前
基于Java+SpringBoot+Vue的美甲店管理系统【附源码+文档+部署视频+讲解)
vue.js·spring boot·后端·毕业设计·计算机毕业设计
修己xj1 小时前
FlatNas:打造你的专属浏览器仪表盘,一个集优雅与实用于一身的开源导航页
前端
哆啦A梦15881 小时前
【vue实战】商城后台管理系统 03 首页-路由界面基础搭建
前端·javascript·vue.js
几何心凉1 小时前
小白上手代理网络,搭建自己的数据抓取工具
前端
蜗牛攻城狮1 小时前
ES6 Module 导入导出完全指南:语法、原理与最佳实践
前端·ecmascript·es6
张拭心7 小时前
Cursor 又偷偷更新,这个功能太实用:Visual Editor for Cursor Browser
前端·人工智能
I'm Jie8 小时前
深入了解 Vue 3 组件间通信机制
前端·javascript·vue.js
用户90443816324609 小时前
90%前端都踩过的JS内存黑洞:从《你不知道的JavaScript》解锁底层逻辑与避坑指南
前端·javascript·面试