当前位置:首页 > VUE

vue实现过渡效果

2026-03-29 09:43:33VUE

Vue 过渡效果实现方法

Vue 提供了内置的 <transition><transition-group> 组件,用于在元素或组件进入/离开 DOM 时应用过渡效果。

基本过渡效果

使用 <transition> 组件包裹需要过渡的元素,通过 CSS 类名定义过渡样式:

<transition name="fade">
  <div v-if="show">内容</div>
</transition>

对应的 CSS 样式:

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

自定义过渡类名

可以覆盖默认的类名,与第三方动画库(如 Animate.css)配合使用:

<transition
  enter-active-class="animate__animated animate__fadeIn"
  leave-active-class="animate__animated animate__fadeOut"
>
  <div v-if="show">内容</div>
</transition>

JavaScript 钩子

通过 JavaScript 实现更复杂的过渡效果:

<transition
  @before-enter="beforeEnter"
  @enter="enter"
  @after-enter="afterEnter"
  @enter-cancelled="enterCancelled"
  @before-leave="beforeLeave"
  @leave="leave"
  @after-leave="afterLeave"
  @leave-cancelled="leaveCancelled"
>
  <div v-if="show">内容</div>
</transition>

对应的方法:

methods: {
  beforeEnter(el) {
    // 进入前状态
  },
  enter(el, done) {
    // 进入动画
    done() // 调用表示动画完成
  }
  // 其他钩子方法...
}

列表过渡

使用 <transition-group> 为列表元素添加过渡效果:

<transition-group name="list" tag="ul">
  <li v-for="item in items" :key="item.id">
    {{ item.text }}
  </li>
</transition-group>

对应的 CSS:

.list-enter-active, .list-leave-active {
  transition: all 1s;
}
.list-enter, .list-leave-to {
  opacity: 0;
  transform: translateY(30px);
}

过渡模式

设置过渡模式控制进入和离开的顺序:

vue实现过渡效果

<transition name="fade" mode="out-in">
  <button v-if="show" key="save">保存</button>
  <button v-else key="edit">编辑</button>
</transition>

常见过渡效果实现

淡入淡出效果

.fade-enter-active, .fade-leave-active {
  transition: opacity 0.3s ease;
}
.fade-enter, .fade-leave-to {
  opacity: 0;
}

滑动效果

.slide-enter-active {
  transition: all 0.3s ease-out;
}
.slide-leave-active {
  transition: all 0.3s ease-in;
}
.slide-enter {
  transform: translateX(100%);
}
.slide-leave-to {
  transform: translateX(-100%);
}

缩放效果

.scale-enter-active, .scale-leave-active {
  transition: all 0.3s;
}
.scale-enter, .scale-leave-to {
  transform: scale(0);
}

注意事项

  • 为列表项设置唯一的 key 属性
  • 过渡性能优化:避免使用会影响布局的属性(如 height
  • 复杂的动画建议使用 CSS transform 和 opacity 属性
  • 对于初始渲染的过渡,可以使用 appear 属性

Vue 的过渡系统可以与多种 CSS 动画库集成,如 Animate.css、GSAP 等,实现更丰富的动画效果。

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

相关文章

vue实现文字

vue实现文字

Vue 中实现文字显示的方法 在 Vue 中实现文字显示可以通过多种方式,包括插值表达式、指令、组件等。以下是几种常见的实现方法: 插值表达式 使用双大括号 {{ }} 进行文本插值,这是 Vue…

vue实现frame

vue实现frame

Vue 中实现 iframe 的方法 在 Vue 中可以通过直接使用 <iframe> 标签或动态绑定 src 属性来实现 iframe 功能。 基本用法 <template&g…

vue实现webapp

vue实现webapp

Vue 实现 WebApp 的基本步骤 环境准备 确保已安装 Node.js 和 npm/yarn。通过 Vue CLI 或 Vite 创建项目: npm install -g @vue/cli v…

vue实现gps

vue实现gps

Vue 中实现 GPS 定位功能 在 Vue 中实现 GPS 定位功能通常依赖于浏览器的 Geolocation API 或第三方地图服务(如高德、百度地图等)。以下是两种常见的实现方式: 使用浏览…

vue实现页面

vue实现页面

Vue 实现页面的基本方法 创建 Vue 项目 使用 Vue CLI 快速初始化项目,运行以下命令安装并创建项目: npm install -g @vue/cli vue create my-pro…

实现vue vm

实现vue vm

Vue VM 实现方法 Vue VM(ViewModel)是 Vue.js 的核心概念之一,负责连接视图(View)和数据模型(Model)。以下是实现 Vue VM 的几种方法: 使用 Vue 实…