当前位置:首页 > VUE

vue div实现折叠效果

2026-02-24 20:01:39VUE

使用 Vue 实现折叠效果

通过 v-show 或 v-if 控制显隐

通过 Vue 的指令 v-showv-if 可以简单实现折叠效果。v-show 通过 CSS 的 display 属性切换,v-if 会动态添加或移除 DOM 元素。

<template>
  <div>
    <button @click="isCollapsed = !isCollapsed">
      {{ isCollapsed ? '展开' : '折叠' }}
    </button>
    <div v-show="!isCollapsed">
      这里是需要折叠的内容
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      isCollapsed: false
    }
  }
}
</script>

添加过渡动画

使用 Vue 的 <transition> 组件可以为折叠效果添加平滑的动画。

<template>
  <div>
    <button @click="isCollapsed = !isCollapsed">
      {{ isCollapsed ? '展开' : '折叠' }}
    </button>
    <transition name="fade">
      <div v-show="!isCollapsed">
        这里是需要折叠的内容
      </div>
    </transition>
  </div>
</template>

<script>
export default {
  data() {
    return {
      isCollapsed: false
    }
  }
}
</script>

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

动态高度过渡

如果需要实现高度变化的过渡效果,可以使用 max-height 结合 CSS 过渡。

<template>
  <div>
    <button @click="isCollapsed = !isCollapsed">
      {{ isCollapsed ? '展开' : '折叠' }}
    </button>
    <div class="collapse-content" :class="{ 'collapsed': isCollapsed }">
      这里是需要折叠的内容
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      isCollapsed: false
    }
  }
}
</script>

<style>
.collapse-content {
  max-height: 500px;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.collapse-content.collapsed {
  max-height: 0;
}
</style>

使用第三方库

如果需要更复杂的折叠效果,可以借助第三方库如 vue-collapsev-collapse

安装 vue-collapse

npm install vue-collapse

示例代码:

<template>
  <div>
    <button @click="isCollapsed = !isCollapsed">
      {{ isCollapsed ? '展开' : '折叠' }}
    </button>
    <vue-collapse v-model="isCollapsed">
      <div>
        这里是需要折叠的内容
      </div>
    </vue-collapse>
  </div>
</template>

<script>
import { VueCollapse } from 'vue-collapse'

export default {
  components: {
    VueCollapse
  },
  data() {
    return {
      isCollapsed: false
    }
  }
}
</script>

总结

以上方法可以根据需求选择:

  • 简单显隐:v-showv-if
  • 平滑过渡:<transition> 组件
  • 高度动画:动态设置 max-height
  • 复杂需求:第三方库如 vue-collapse

vue div实现折叠效果

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

相关文章

vue实现文章锚点定位

vue实现文章锚点定位

实现文章锚点定位的方法 在Vue中实现文章锚点定位可以通过多种方式完成,以下是几种常见的方法: 使用原生HTML锚点 通过HTML的id属性和<a>标签的href属性实现锚点跳转。在V…

vue   实现单选

vue 实现单选

Vue 实现单选功能 在 Vue 中实现单选功能可以通过多种方式,以下是几种常见的方法: 使用原生 <input type="radio"> 绑定 v-model 通过 v-model…

vue实现看板

vue实现看板

Vue 实现看板功能 使用 Vue 实现看板功能可以通过组件化开发、状态管理和拖拽库结合完成。以下是一个完整的实现方案: 基础项目结构 src/ ├── components/ │ ├── Ka…

vue首页实现

vue首页实现

实现Vue首页的基本步骤 创建一个Vue首页通常涉及项目初始化、页面结构设计、路由配置和组件开发。以下是具体实现方法: 初始化Vue项目 使用Vue CLI或Vite快速搭建项目结构: npm i…

vue监听实现

vue监听实现

Vue 监听实现方法 在 Vue 中可以通过多种方式实现监听数据变化或事件触发,以下是常见的几种方法: 使用 watch 选项 watch 是 Vue 提供的核心功能之一,用于观察和响应 Vue…

vue 实现遮罩

vue 实现遮罩

Vue 实现遮罩层的方法 使用固定定位和透明背景 在Vue中实现遮罩层可以通过CSS固定定位结合透明背景色完成。创建一个全屏遮罩组件,利用position: fixed覆盖整个视窗。 <te…