当前位置:首页 > VUE

vue 实现点击切换tab

2026-01-20 16:32:20VUE

Vue 实现点击切换 Tab 的方法

使用 v-if/v-show 控制显示

通过 v-ifv-show 结合 data 属性控制不同 Tab 内容的显示隐藏。v-if 会销毁和重建 DOM 元素,适合切换频率低的场景;v-show 通过 CSS 控制显示,适合频繁切换的场景。

<template>
  <div>
    <div class="tabs">
      <button @click="activeTab = 'tab1'">Tab 1</button>
      <button @click="activeTab = 'tab2'">Tab 2</button>
    </div>
    <div class="content">
      <div v-if="activeTab === 'tab1'">Content 1</div>
      <div v-if="activeTab === 'tab2'">Content 2</div>
    </div>
  </div>
</template>

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

使用动态组件

通过 Vue 的 <component :is="currentComponent"> 动态组件特性实现 Tab 切换,适合每个 Tab 对应独立组件的情况。

vue 实现点击切换tab

<template>
  <div>
    <button @click="currentComponent = 'ComponentA'">Component A</button>
    <button @click="currentComponent = 'ComponentB'">Component B</button>
    <component :is="currentComponent"></component>
  </div>
</template>

<script>
import ComponentA from './ComponentA.vue'
import ComponentB from './ComponentB.vue'

export default {
  components: {
    ComponentA,
    ComponentB
  },
  data() {
    return {
      currentComponent: 'ComponentA'
    }
  }
}
</script>

使用路由切换

对于 SPA 应用,可以通过 Vue Router 实现 Tab 切换,每个 Tab 对应一个路由路径。

vue 实现点击切换tab

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

使用第三方 UI 库

Element UI、Ant Design Vue 等库提供现成的 Tab 组件,可直接使用。

<template>
  <el-tabs v-model="activeTab">
    <el-tab-pane label="Tab 1" name="tab1">Content 1</el-tab-pane>
    <el-tab-pane label="Tab 2" name="tab2">Content 2</el-tab-pane>
  </el-tabs>
</template>

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

添加过渡动画

通过 Vue 的 <transition> 组件为 Tab 切换添加过渡效果。

<transition name="fade" mode="out-in">
  <div v-if="activeTab === 'tab1'" key="tab1">Content 1</div>
  <div v-else key="tab2">Content 2</div>
</transition>

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

标签: vuetab
分享给朋友:

相关文章

vue实现granfana

vue实现granfana

Vue 实现类似 Grafana 的仪表盘 要在 Vue 中实现类似 Grafana 的仪表盘功能,需要结合数据可视化库、状态管理和 UI 组件。以下是关键步骤和推荐工具: 数据可视化库 使用 E…

vue 动画实现

vue 动画实现

Vue 动画实现方式 Vue 提供了多种方式实现动画效果,主要分为内置组件和第三方库集成。 使用 Vue 内置过渡组件 Vue 的 <transition> 和 <transiti…

vue实现分栏

vue实现分栏

Vue实现分栏的常见方法 使用CSS Flexbox布局 通过Flexbox可以快速实现分栏效果,适合大多数响应式布局场景 <template> <div class="con…

vue实现快递查询

vue实现快递查询

实现思路 通过调用第三方快递查询API接口,结合Vue.js框架实现快递单号查询功能。需要用户输入快递单号和选择快递公司,点击查询后显示物流信息。 准备工作 注册快递查询API服务(如快递100、聚…

vue自动登录实现

vue自动登录实现

自动登录实现方法 在Vue中实现自动登录功能通常涉及以下几个关键步骤: 使用本地存储保存token 将登录成功后的token保存到localStorage或sessionStorage中,确保浏览器…

vue实现js休眠

vue实现js休眠

Vue 中实现 JavaScript 休眠 在 Vue 中实现 JavaScript 休眠通常需要使用异步方式,以避免阻塞主线程。以下是几种常见方法: 使用 setTimeout 和 Promise…