当前位置:首页 > VUE

vue 实现口风琴

2026-03-08 14:34:17VUE

实现口风琴效果的方法

在Vue中实现口风琴(Accordion)效果,可以通过组件化方式结合动态样式和事件处理来完成。以下是几种常见的实现方式:

使用v-for和v-show/v-if

通过循环渲染多个折叠面板,利用v-showv-if控制内容展开与折叠:

vue 实现口风琴

<template>
  <div class="accordion">
    <div 
      v-for="(item, index) in items" 
      :key="index" 
      class="accordion-item"
    >
      <div 
        class="accordion-header" 
        @click="toggle(index)"
      >
        {{ item.title }}
      </div>
      <div 
        class="accordion-content" 
        v-show="activeIndex === index"
      >
        {{ item.content }}
      </div>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      activeIndex: null,
      items: [
        { title: '标题1', content: '内容1' },
        { title: '标题2', content: '内容2' }
      ]
    }
  },
  methods: {
    toggle(index) {
      this.activeIndex = this.activeIndex === index ? null : index
    }
  }
}
</script>

<style>
.accordion-item {
  margin-bottom: 8px;
}
.accordion-header {
  padding: 12px;
  background: #f0f0f0;
  cursor: pointer;
}
.accordion-content {
  padding: 12px;
  border: 1px solid #ddd;
}
</style>

使用组件递归实现嵌套口风琴

对于需要嵌套结构的情况,可以创建递归组件:

<template>
  <accordion-item 
    v-for="item in items" 
    :item="item" 
    :key="item.id"
  />
</template>

<script>
import AccordionItem from './AccordionItem.vue'

export default {
  components: { AccordionItem },
  data() {
    return {
      items: [
        { 
          id: 1, 
          title: '父级1',
          children: [
            { id: 11, title: '子级1', content: '内容1' }
          ]
        }
      ]
    }
  }
}
</script>

使用第三方库

现成的Vue组件库如Element UI、Vuetify等已提供口风琴组件:

vue 实现口风琴

<template>
  <el-collapse v-model="activeNames">
    <el-collapse-item 
      v-for="item in items" 
      :title="item.title" 
      :name="item.id"
    >
      {{ item.content }}
    </el-collapse-item>
  </el-collapse>
</template>

<script>
export default {
  data() {
    return {
      activeNames: [],
      items: [
        { id: 1, title: '标题1', content: '内容1' }
      ]
    }
  }
}
</script>

添加过渡动画

通过Vue的<transition>组件实现平滑的展开/折叠动画:

<transition name="slide">
  <div 
    class="accordion-content" 
    v-show="activeIndex === index"
  >
    {{ item.content }}
  </div>
</transition>

<style>
.slide-enter-active, .slide-leave-active {
  transition: max-height 0.3s ease;
  overflow: hidden;
}
.slide-enter-from, .slide-leave-to {
  max-height: 0;
}
.slide-enter-to, .slide-leave-from {
  max-height: 500px;
}
</style>

可访问性优化

遵循WAI-ARIA标准增强可访问性:

<div 
  role="button" 
  :aria-expanded="activeIndex === index" 
  tabindex="0"
  @keydown.enter="toggle(index)"
>
  标题
</div>
<div 
  role="region" 
  :aria-hidden="activeIndex !== index"
>
  内容
</div>

以上方法可根据实际需求组合使用,构建功能完善的口风琴组件。

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

相关文章

vue实现录播播放

vue实现录播播放

Vue 实现录播播放 使用 video.js 实现 安装 video.js 和相关的 Vue 适配器: npm install video.js @videojs-player/vue 在 Vue…

vue拖拽实现

vue拖拽实现

Vue 拖拽实现方法 使用 HTML5 原生拖拽 API HTML5 提供了原生拖拽 API,可以通过 draggable 属性、dragstart、dragend、dragover 和 drop 事…

vue实现selectable

vue实现selectable

Vue 实现可选择的 Select 组件 在 Vue 中实现一个可选择的 Select 组件,可以通过以下几种方式: 使用原生 HTML select 元素 <template>…

vue实现选择

vue实现选择

Vue 实现选择功能的方法 在 Vue 中实现选择功能可以通过多种方式完成,以下介绍几种常见的实现方法。 使用 v-model 绑定单选 通过 v-model 可以轻松实现单选功能。以下是一个简单的…

vue实现 hover

vue实现 hover

实现 Vue 中的 hover 效果 在 Vue 中实现 hover 效果可以通过多种方式完成,以下是常见的几种方法: 使用 CSS 伪类 最简单的方式是直接使用 CSS 的 :hover 伪类,无…

vue实现eventbus

vue实现eventbus

Vue 中实现 EventBus 在 Vue 中,EventBus 是一种跨组件通信的机制,尤其适用于非父子组件之间的数据传递。以下是实现 EventBus 的几种方法: 方法一:使用 Vue 实例…