Vue第六天---Vue过渡与动画

216 阅读2分钟

Vue过渡与动画

1.css过渡

css中的过渡呈现的是一种过渡过程,简单来说就是一种动画转换过程。

1.1 css过渡的用法

过渡系统是Vue为DOM动画效果提供的一种特性,它能从DOM中插入、移除时触发css过渡和动画;也就是说,在DOM发生变化时,为其添加特定的class类名。

几种过渡元素

将需要过渡效果的元素放在标签中,在style标签中添加.v-xxx

  • V-enter:定义进入过渡的开始状态,在元素被插入前生效,在元素被插入后的下一帧移除。
  • v-enter-activate:定义进入过渡生效时的状态,这个类可以被用来定义进入过渡的过程时间、延迟和曲线函数,在元素被插入前生效,在过渡完成后移除。
  • v-enter-to:定义进入过渡的结束状态,v-enter被移除时生效,在过渡完成时移除。
  • v-leave:定义离开过渡的开始状态。
  • v-leave-activate:定义离开过渡生效时的状态。
  • v-leave-to:定义离开过渡的结束状态。

2.多个元素过渡

过渡模式分为两种:

out-in模式:当前元素先进行过渡,完成后新元素过渡进入

in-out模式:新元素先进行过渡,完成后当前元素过渡离开

<transition name="xxx" mode="out-in"></transition>

3.动画

 <!DOCTYPE html>
 <html lang="en">
 <head>
     <meta charset="UTF-8">
     <title>Vue中同时使用过渡和动画</title>
     <script src="../../easy_start/js/vue.js" type="text/javascript" charset="UTF-8"></script>
     <link rel="stylesheet" href="https://cdn.bootcss.com/animate.css/3.5.2/animate.css">
     <style>
         .fade-enter,
         .fade-leave-to{
             opacity:0;
         }
         .fade-enter-activate,
         .fade-leave-activate{
             transition:opacity 3s;
         }
     </style>
 </head>
 <body>
 <div id="app">
     <transition
             type="transition" name="fade"
             appear
             enter-active-class="animated swing fade-enter-activate"
             leave-active-class="animated shake fade-leave-activate"
             appear-active-class="animated swing">
         <div v-if="show">Hi Shelgi</div>
     </transition>
     <button @click="Click">点点我</button>
 </div>
 ​
 <script>
     var vm=new Vue({
         el:"#app",
         data: {
             show: true,
         },
         methods:{
             Click:function(){
                 this.show=!this.show
             }
         }
     })
 </script>
 </body>
 </html>

image-20211109204722568

点击就会看到过渡动画

当然可以依赖css动画库,也能依赖js动画库

  • keyframes:css的动画库
  • Animate.css:css的动画库
  • Velocity.js:js的动画库

总结

过渡动画实现的三种方式是:

  • 使用Vue的标签结合css样式完成动画
  • 利用Animate.css结合实现动画
  • 利用Vue中钩子函数实现动画