当前位置:首页 > VUE

vue实现进入动画

2026-01-16 00:28:23VUE

Vue 进入动画实现方法

使用 Vue 的过渡系统实现进入动画,主要通过 <transition><transition-group> 组件结合 CSS 或 JavaScript 钩子完成。

CSS 过渡动画

定义进入动画的 CSS 类名,Vue 会自动在适当时机添加/移除这些类:

<transition name="fade">
  <div v-if="show">内容</div>
</transition>
.fade-enter-active {
  transition: opacity 0.5s;
}
.fade-enter-from {
  opacity: 0;
}

CSS 动画

使用 @keyframes 定义动画效果:

.bounce-enter-active {
  animation: bounce-in 0.5s;
}
@keyframes bounce-in {
  0% {
    transform: scale(0);
  }
  50% {
    transform: scale(1.25);
  }
  100% {
    transform: scale(1);
  }
}

JavaScript 钩子

通过监听过渡的生命周期事件实现更复杂的动画:

<transition
  @before-enter="beforeEnter"
  @enter="enter"
  @after-enter="afterEnter">
  <div v-if="show">内容</div>
</transition>
methods: {
  beforeEnter(el) {
    el.style.opacity = 0
    el.style.transformOrigin = 'left'
  },
  enter(el, done) {
    gsap.to(el, {
      opacity: 1,
      x: 0,
      duration: 0.8,
      onComplete: done
    })
  }
}

第三方动画库

集成 Animate.css 等现成动画库:

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

列表过渡

对多个元素使用 <transition-group> 实现进入动画:

<transition-group name="list" tag="ul">
  <li v-for="item in items" :key="item.id">
    {{ item.text }}
  </li>
</transition-group>
.list-enter-active {
  transition: all 1s;
}
.list-enter-from {
  opacity: 0;
  transform: translateY(30px);
}

初始渲染动画

使用 appear 属性让元素在初始渲染时也有动画:

<transition
  appear
  appear-class="custom-appear-class"
  appear-to-class="custom-appear-to-class"
  appear-active-class="custom-appear-active-class">
  <div>内容</div>
</transition>

动态过渡

根据状态动态改变过渡效果:

vue实现进入动画

<transition :name="transitionName">
  <div v-if="show">内容</div>
</transition>
data() {
  return {
    transitionName: 'fade'
  }
}

每种方法适用于不同场景,CSS 过渡适合简单动画,JavaScript 钩子适合复杂交互,第三方库能快速实现专业效果,列表过渡处理多个元素动画。根据项目需求选择合适方案,注意动画性能优化避免卡顿。

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

相关文章

vue实现高亮

vue实现高亮

Vue 实现文本高亮的方法 在 Vue 中实现文本高亮可以通过多种方式完成,以下是几种常见的方法: 方法一:使用 v-html 指令 通过 v-html 指令可以动态插入 HTML 内容,将需要高…

vue实现图片

vue实现图片

Vue 实现图片功能的方法 静态图片引入 在 Vue 项目中,可以通过 src 属性直接引入静态图片。图片通常放在 public 或 assets 目录下。 <template> &…

vue实现素材

vue实现素材

Vue 实现素材的方法 使用 Vue 组件管理素材 在 Vue 项目中,可以通过组件化的方式管理素材。创建一个专门的组件来加载和显示素材,例如图片、视频或音频文件。组件可以接收素材的路径或 URL 作…

vue实现计算

vue实现计算

Vue 实现计算的方法 在 Vue 中实现计算功能可以通过多种方式完成,主要包括计算属性(computed)、方法(methods)和侦听器(watch)。以下是具体的实现方法: 计算属性(Comp…

vue环境实现

vue环境实现

Vue 环境搭建 安装 Node.js 和 npm Node.js 是运行 Vue 的基础环境,npm 是包管理工具。从 Node.js 官网 下载并安装最新稳定版本。安装完成后,在终端运行以下命令验…

vue实现通讯

vue实现通讯

Vue 组件通讯方法 父子组件通讯 父组件向子组件传递数据通过 props,子组件向父组件传递数据通过 $emit 事件。 父组件模板: <child-component :message=…