Vite+Vue3项目使用第三方Animate.css动画库简单实现页面级的路由转场动画详细教程

vue通过第三方集成Animate.css简单快速的实现动画,通过类名引用,可以轻松实现Animate的所有动画,Animate.css是一款强大的预设css3动画库,Animate.css内置了很多典型的css3动画,兼容性好使用方便。

一、页面级路由转场动画实现思路参考

在这里插入图片描述

Vue Router官方过渡动效教程:https://router.vuejs.org/zh/guide/advanced/transitions.html

二、安装并全局导入Animate.css

  • 安装
 npm install animate.css
  • 全局导入
//animate动画库引入
import 'animate.css'

三、编写App.vue下RouterView相关代码

根据每个路由自定义的meta的动画类名,把自定义的路由动画animate.css导入到enter-active-class和leave-active-class当中实现不同页面使用不同的页面级路由专场动画。

  • enter-active-class:设置进入的动画类名
  • leave-active-class:设置离开的动画类名
<router-view v-slot="{ Component, route }">
    <transition 
    name="fade"
    :enter-active-class="route.meta.e_class"
    :leave-active-class="route.meta.l_class"
  >
    <component :is="Component" />
  </transition>
</router-view>

四、自定义路由meta的动画参数

import { createRouter,useRouter , createWebHistory } from 'vue-router'

const router = createRouter({
  history: createWebHistory(import.meta.env.BASE_URL),
  routes: [
    {
      path: '/',
      name: 'index',
      meta: { 
        header:false,
        footer:true,
        e_class:"animate__animated",
        l_class:"animate__animated animate__fadeOutLeft"
      },
      component: () => import('../views/index.vue')
    },
    {
      path: '/login',
      name: 'login',
      meta: { 
        header:true,
        footer:true,
        e_class:"animate__animated animate__fadeInLeft",
        l_class:"animate__animated animate__fadeOutLeft"
      },
      component: () => import('../views/login.vue')
    }
});

本文原创,原创不易,如需转载,请联系作者授权。

### Vue3使用 Transition 组件与 Animate.css 结合实现动画 #### 安装 Animate.cssVue3 项目使用 `animate.css`,首先需要通过 npm 或 yarn 来安装此库: ```bash npm install animate.css --save ``` 或者 ```bash yarn add animate.css ``` #### 导入 Animate.css 文件 完成安装之后,在项目的入口文件(通常是 main.js 或者 vite.config.ts 如果使用 Vite 构建工具),添加以下代码来全局引入 `animate.css`: ```javascript import &#39;animate.css&#39;; ``` 这一步骤确保整个应用程序都可以访问到 `animate.css` 提供的所有动画效果。 #### 创建带有过渡效果的组件 创建一个新的 Vue 组件,并在其内部定义一个布尔类型的响应式属性用于控制显示/隐藏状态。接着应用 `<transition>` 标签包裹目标 DOM 节点,并指定进入和离开时所需的 CSS 类名[^2]。 下面给出一段完整的示例代码展示如何在一个按钮点击事件触发下切换表情符号的可见性以及伴随淡入淡出的效果[^3]: ```html <template> <button @click="toggle">Toggle</button> <!-- 使用 transition 包裹要执行动画的目标 --> <Transition name="custom-classes-transition" :enter-active-class="&#39;animate__animated animate__fadeIn&#39;" :leave-active-class="&#39;animate__animated animate__fadeOut&#39;" > <p v-if="show"> Hello, world! {{ emoji }} </p> </Transition> </template> <script setup lang="ts"> import { ref } from &#39;vue&#39;; const show = ref(false); let emoji = ref(&#39;😊&#39;); function toggle() { show.value = !show.value; } </script> ``` 在这个例子中,当点击按钮改变 `show` 变量的状态时,会触发表情文字区域按照设定好的方式逐渐显现或消失。这里特别需要注意的是对于版本大于等于 V4 的 `animate.css`,除了基本的动画类之外还需要额外加上 `animate__animated` 前缀才能让动画正常工作[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值