当前位置:首页 > VUE

vue实现动画

2026-02-10 06:27:52VUE

Vue 动画实现方法

Vue 提供了多种方式实现动画效果,主要依赖于内置的 <transition><transition-group> 组件,以及结合 CSS 或 JavaScript 钩子。

使用 <transition> 组件实现单元素动画

通过包裹需要动画的元素,Vue 会在元素插入或移除时自动添加过渡类名:

<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;
}

使用 CSS 动画

定义关键帧动画并应用于 Vue 过渡:

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

JavaScript 钩子实现动画

通过事件钩子实现更复杂的动画逻辑:

<transition
  @before-enter="beforeEnter"
  @enter="enter"
  @leave="leave"
>
  <div v-if="show">内容</div>
</transition>

对应的 JavaScript 方法:

vue实现动画

methods: {
  beforeEnter(el) {
    el.style.opacity = 0;
    el.style.transformOrigin = 'left';
  },
  enter(el, done) {
    anime({
      targets: el,
      opacity: 1,
      translateX: [20, 0],
      duration: 300,
      easing: 'easeInOutQuad',
      complete: 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);
}
.list-move {
  transition: transform 1s;
}

第三方动画库集成

与 Animate.css 等库结合使用:

vue实现动画

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

状态驱动的动画

使用 Vue 的响应式系统和计算属性实现状态动画:

computed: {
  animatedStyle() {
    return {
      transform: `rotate(${this.rotation}deg)`,
      transition: 'transform 0.5s ease'
    };
  }
}

在模板中应用:

<div :style="animatedStyle">旋转元素</div>

路由过渡动画

为 Vue Router 添加页面切换动画:

<router-view v-slot="{ Component }">
  <transition name="route" mode="out-in">
    <component :is="Component" />
  </transition>
</router-view>

对应的 CSS 样式:

.route-enter-active, .route-leave-active {
  transition: opacity 0.3s, transform 0.3s;
}
.route-enter-from, .route-leave-to {
  opacity: 0;
  transform: translateX(30px);
}

以上方法可根据具体需求组合使用,实现从简单到复杂的各种动画效果。

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

相关文章

vue实现前端分离

vue实现前端分离

Vue 实现前后端分离 前后端分离是一种架构模式,前端负责页面渲染和交互逻辑,后端提供数据接口。Vue.js 作为前端框架,非常适合实现前后端分离的开发模式。 核心实现步骤 创建 Vue 项目 使用…

vue 实现tabs

vue 实现tabs

Vue 实现 Tabs 组件的方法 使用动态组件和 v-for 在 Vue 中实现 Tabs 可以通过动态组件和 v-for 指令结合完成。定义一个 tabs 数组,包含每个标签的标题和对应的组件。…

vue element实现

vue element实现

Vue Element UI 实现 Vue Element UI 是基于 Vue.js 的组件库,提供丰富的 UI 组件,适合快速开发企业级中后台产品。以下是一些关键实现方法和步骤: 安装 Vue…

vue 实现级联

vue 实现级联

Vue 实现级联选择器 级联选择器(Cascader)常用于省市区选择、分类选择等场景。Vue 中可以通过 Element UI、Ant Design Vue 等 UI 库实现,也可以手动封装。 使…

vue实现图册

vue实现图册

Vue实现图册功能 在Vue中实现图册功能通常涉及图片展示、切换、缩放等交互效果。以下是常见的实现方法和关键代码示例: 基础图册组件结构 使用Vue单文件组件构建基础结构: <templat…

vue  实现tab

vue 实现tab

实现 Tab 切换功能 在 Vue 中实现 Tab 切换功能可以通过动态组件或条件渲染完成。以下是两种常见方法: 使用 v-if 或 v-show 实现条件渲染 通过绑定 currentTab 变量…