Vue 提供了 transition 的封装组件,在下列情形中,可以给任何元素和组件添加进入/离开过渡:

  • 条件渲染 (使用 v-if)
  • 条件展示 (使用 v-show)
  • 动态组件
  • 组件根节点

自定义 transition 过度效果,你需要对transition组件的name属性自定义。并在css中写入对应的样式

1.过渡的类名

在进入/离开的过渡中,会有 6 个 class 切换。

  1. 过渡 class

    1. 在进入/离开的过渡中,会有 6 class 切换。
  2. v-enter-from:定义进入过渡的开始状态。在元素被插入之前生效,在元素被插入之后的下一帧移除。

  3. v-enter-active:定义进入过渡生效时的状态。在整个进入过渡的阶段中应用,在元素被插入之前生效,在过渡/动画完成之后移除。这个类可以被用来定义进入过渡的过程时间,延迟和曲线函数。
  4. v-enter-to:定义进入过渡的结束状态。在元素被插入之后下一帧生效 (与此同时 v-enter-from 被移除),在过渡/动画完成之后移除。
  5. v-leave-from:定义离开过渡的开始状态。在离开过渡被触发时立刻生效,下一帧被移除。
  6. v-leave-active:定义离开过渡生效时的状态。在整个离开过渡的阶段中应用,在离开过渡被触发时立刻生效,在过渡/动画完成之后移除。这个类可以被用来定义离开过渡的过程时间,延迟和曲线函数。
  7. v-leave-to:离开过渡的结束状态。在离开过渡被触发之后下一帧生效 (与此同时 v-leave-from 被移除),在过渡/动画完成之后移除。

如下

  1. <button @click='flag = !flag'>切换</button>
  2. <transition name='fade'>
  3. <div v-if='flag' class="box"></div>
  4. </transition>
  1. //开始过度
  2. .fade-enter-from{
  3. background:red;
  4. width:0px;
  5. height:0px;
  6. transform:rotate(360deg)
  7. }
  8. //开始过度了
  9. .fade-enter-active{
  10. transition: all 2.5s linear;
  11. }
  12. //过度完成
  13. .fade-enter-to{
  14. background:yellow;
  15. width:200px;
  16. height:200px;
  17. }
  18. //离开的过度
  19. .fade-leave-from{
  20. width:200px;
  21. height:200px;
  22. transform:rotate(360deg)
  23. }
  24. //离开中过度
  25. .fade-leave-active{
  26. transition: all 1s linear;
  27. }
  28. //离开完成
  29. .fade-leave-to{
  30. width:0px;
  31. height:0px;
  32. }

2.自定义过渡 class 类名

trasnsition props

  • enter-from-class
  • enter-active-class
  • enter-to-class
  • leave-from-class
  • leave-active-class
  • leave-to-class

自定义过度时间 单位毫秒
你也可以分别指定进入和离开的持续时间:

  1. <transition :duration="1000">...</transition>
  2. <transition :duration="{ enter: 500, leave: 800 }">...</transition>

通过自定义class 结合css动画库animate css
安装库 npm install animate.css
引入 import ‘animate.css’
使用方法
官方文档 Animate.css | A cross-browser library of CSS animations.

  1. <transition
  2. leave-active-class="animate__animated animate__bounceInLeft"
  3. enter-active-class="animate__animated animate__bounceInRight"
  4. >
  5. <div v-if="flag" class="box"></div>
  6. </transition>

3.transition 生命周期8个

  1. @before-enter="beforeEnter" //对应enter-from
  2. @enter="enter"//对应enter-active
  3. @after-enter="afterEnter"//对应enter-to
  4. @enter-cancelled="enterCancelled"//显示过度打断
  5. @before-leave="beforeLeave"//对应leave-from
  6. @leave="leave"//对应enter-active
  7. @after-leave="afterLeave"//对应leave-to
  8. @leave-cancelled="leaveCancelled"//离开过度打断

当只用 JavaScript 过渡的时候,在 enter 和 leave 钩子中必须使用 done 进行回调
结合gsap 动画库使用 GreenSock

  1. const beforeEnter = (el: Element) => {
  2. console.log('进入之前from', el);
  3. }
  4. const Enter = (el: Element,done:Function) => {
  5. console.log('过度曲线');
  6. setTimeout(()=>{
  7. done()
  8. },3000)
  9. }
  10. const AfterEnter = (el: Element) => {
  11. console.log('to');
  12. }

4.appear

通过这个属性可以设置初始节点过度 就是页面加载完成就开始动画 对应三个状态

  1. appear-active-class=""
  2. appear-from-class=""
  3. appear-to-class=""
  4. appear

————————————————
版权声明:本文为CSDN博主「小满zs」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq1195566313/article/details/123000653
————————————————
版权声明:本文为CSDN博主「小满zs」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq1195566313/article/details/123000653