当前位置:首页 > VUE

vue 实现table切换

2026-01-16 00:31:10VUE

实现 Vue 表格切换功能

在 Vue 中实现表格切换功能通常涉及动态渲染不同的表格数据或切换不同的表格样式。以下是几种常见的实现方式:

动态数据切换

通过改变表格绑定的数据源实现切换:

<template>
  <div>
    <button @click="currentTable = 'table1'">表格1</button>
    <button @click="currentTable = 'table2'">表格2</button>

    <table>
      <thead>
        <tr>
          <th v-for="col in columns" :key="col">{{ col }}</th>
        </tr>
      </thead>
      <tbody>
        <tr v-for="row in activeData" :key="row.id">
          <td v-for="col in columns" :key="col">{{ row[col] }}</td>
        </tr>
      </tbody>
    </table>
  </div>
</template>

<script>
export default {
  data() {
    return {
      currentTable: 'table1',
      table1Data: [...],
      table2Data: [...],
      columns: ['id', 'name', 'age']
    }
  },
  computed: {
    activeData() {
      return this.currentTable === 'table1' ? this.table1Data : this.table2Data
    }
  }
}
</script>

组件切换方式

使用动态组件切换不同的表格组件:

<template>
  <div>
    <button @click="currentComponent = 'TableA'">表格A</button>
    <button @click="currentComponent = 'TableB'">表格B</button>

    <component :is="currentComponent" :data="tableData"/>
  </div>
</template>

<script>
import TableA from './TableA.vue'
import TableB from './TableB.vue'

export default {
  components: { TableA, TableB },
  data() {
    return {
      currentComponent: 'TableA',
      tableData: [...]
    }
  }
}
</script>

条件渲染

使用 v-if/v-show 控制不同表格的显示:

<template>
  <div>
    <button @click="showTable1 = true; showTable2 = false">表格1</button>
    <button @click="showTable1 = false; showTable2 = true">表格2</button>

    <table v-if="showTable1">
      <!-- 表格1内容 -->
    </table>

    <table v-if="showTable2">
      <!-- 表格2内容 -->
    </table>
  </div>
</template>

使用第三方表格组件

结合 Element UI 或 Ant Design Vue 等 UI 库实现:

<template>
  <div>
    <el-radio-group v-model="currentTable">
      <el-radio-button label="table1">表格1</el-radio-button>
      <el-radio-button label="table2">表格2</el-radio-button>
    </el-radio-group>

    <el-table :data="activeData">
      <el-table-column prop="name" label="姓名"></el-table-column>
      <el-table-column prop="age" label="年龄"></el-table-column>
    </el-table>
  </div>
</template>

带过渡动画的切换

为表格切换添加过渡效果:

vue 实现table切换

<template>
  <div>
    <transition name="fade" mode="out-in">
      <table v-if="showTable1" key="table1">
        <!-- 表格1内容 -->
      </table>
      <table v-else key="table2">
        <!-- 表格2内容 -->
      </table>
    </transition>
  </div>
</template>

<style>
.fade-enter-active, .fade-leave-active {
  transition: opacity 0.5s;
}
.fade-enter, .fade-leave-to {
  opacity: 0;
}
</style>

选择哪种实现方式取决于具体需求。动态数据切换适合数据结构相同的表格,组件切换适合结构差异大的表格,条件渲染适合简单的切换场景,第三方组件能快速实现专业效果。

标签: vuetable
分享给朋友:

相关文章

vue筛选实现

vue筛选实现

Vue 筛选实现方法 使用计算属性实现筛选 计算属性是 Vue 中实现数据筛选的常用方式。通过定义一个计算属性,可以根据输入的条件动态过滤数据。 <template> <div…

vue实现单据

vue实现单据

Vue 实现单据功能的方法 使用 Vue 实现单据功能通常涉及表单设计、数据绑定、验证和提交等环节。以下是具体实现方案: 表单设计与数据绑定 使用 Vue 的 v-model 指令实现表单数据的双向…

vue实现拖动

vue实现拖动

Vue实现拖动的常用方法 在Vue中实现拖动功能通常需要结合HTML5的拖放API或第三方库。以下是几种常见实现方式: 使用HTML5原生拖放API HTML5提供了原生拖放API,可以通过drag…

vue 实现后退

vue 实现后退

实现后退功能的方法 在Vue中实现后退功能通常需要结合浏览器历史记录API或Vue Router的导航方法。以下是几种常见的实现方式: 使用Vue Router的go方法 this.$router…

vue 实现分屏

vue 实现分屏

Vue 实现分屏的方法 使用 CSS Flexbox 或 Grid 布局 通过 CSS Flexbox 或 Grid 布局可以轻松实现分屏效果。在 Vue 组件中定义两个或多个区域,并使用 CSS 控…

vue实现展开

vue实现展开

展开功能的实现方法 在Vue中实现展开功能可以通过多种方式完成,常见的有使用v-show、v-if指令,结合CSS过渡动画或第三方组件库。 使用v-show控制显示隐藏 通过v-show指令可以简单…