当前位置:首页 > VUE

vue实现标签切换

2026-02-18 22:05:07VUE

Vue 实现标签切换的方法

使用动态组件 <component :is>

通过动态组件可以轻松切换不同的子组件。结合 v-forv-if 控制显示逻辑。

vue实现标签切换

<template>
  <div>
    <button 
      v-for="tab in tabs" 
      :key="tab.name" 
      @click="currentTab = tab.name"
    >
      {{ tab.label }}
    </button>
    <component :is="currentTab" />
  </div>
</template>

<script>
import Tab1 from './Tab1.vue';
import Tab2 from './Tab2.vue';

export default {
  components: { Tab1, Tab2 },
  data() {
    return {
      currentTab: 'Tab1',
      tabs: [
        { name: 'Tab1', label: '标签1' },
        { name: 'Tab2', label: '标签2' }
      ]
    };
  }
};
</script>

结合 v-ifv-show

直接通过条件渲染控制标签内容的显隐。

vue实现标签切换

<template>
  <div>
    <button @click="activeTab = 'tab1'">标签1</button>
    <button @click="activeTab = 'tab2'">标签2</button>

    <div v-if="activeTab === 'tab1'">内容1</div>
    <div v-if="activeTab === 'tab2'">内容2</div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      activeTab: 'tab1'
    };
  }
};
</script>

使用 Vue Router

适合需要 URL 同步的标签切换场景。

// router.js
const routes = [
  { path: '/tab1', component: Tab1 },
  { path: '/tab2', component: Tab2 }
];
<template>
  <router-link to="/tab1">标签1</router-link>
  <router-link to="/tab2">标签2</router-link>
  <router-view></router-view>
</template>

第三方组件库

如 Element UI 的 el-tabs 或 Ant Design Vue 的 a-tabs

<template>
  <el-tabs v-model="activeTab">
    <el-tab-pane label="标签1" name="tab1">内容1</el-tab-pane>
    <el-tab-pane label="标签2" name="tab2">内容2</el-tab-pane>
  </el-tabs>
</template>

<script>
export default {
  data() {
    return {
      activeTab: 'tab1'
    };
  }
};
</script>

关键注意事项

  • 性能优化:频繁切换时用 v-show 替代 v-if(避免重复渲染)。
  • 状态保持:使用 <keep-alive> 包裹动态组件可保留组件状态。
  • 路由懒加载:配合 () => import('./Tab1.vue') 提升首屏速度。

标签: 标签vue
分享给朋友:

相关文章

vue实现switch

vue实现switch

Vue 实现 Switch 开关组件 在 Vue 中实现 Switch 开关组件可以通过自定义组件或使用现有 UI 库完成。以下是几种常见实现方式: 自定义 Switch 组件 创建一个基础 Sw…

vue实现换行

vue实现换行

Vue 中实现换行的几种方法 在 Vue 中实现换行可以通过多种方式,具体取决于使用场景和需求。以下是常见的几种方法: 使用 HTML 的 <br> 标签 在模板中直接使用 <br…

vue实现flbook

vue实现flbook

Vue 实现类似 Flbook 的翻页效果 要实现类似 Flbook 的翻页效果,可以使用 Vue 结合 CSS 动画和 JavaScript 事件处理。以下是实现方法: 安装依赖 需要安装 vue…

vue实现导入

vue实现导入

Vue 实现文件导入功能 使用 <input type="file"> 元素 在 Vue 模板中添加一个文件输入元素,绑定 change 事件处理函数。 <template>…

vue实现listview

vue实现listview

Vue 实现 ListView 的方法 基础列表渲染 使用 v-for 指令可以轻松实现基础列表渲染。在 Vue 中,v-for 用于遍历数组或对象,生成动态列表。 <template>…

mui实现vue

mui实现vue

mui 实现 Vue 的步骤 mui 是一个轻量级的前端框架,常用于移动端开发。结合 Vue 可以实现高效的开发体验。以下是具体实现方法。 安装 mui 和 Vue 通过 npm 或 yarn 安装…