(transition动画组件)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了(transition动画组件)相关的知识,希望对你有一定的参考价值。


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

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

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

1.过渡的类名

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

#过渡 class

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

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

如下

<button @click=flag = !flag>切换</button>
<transition name=fade>
<div v-if=flag class="box"></div>
</transition>
//开始过度
.fade-enter-from
background:red;
width:0px;
height:0px;
transform:rotate(360deg)

//开始过度了
.fade-enter-active
transition: all 2.5s linear;

//过度完成
.fade-enter-to
background:yellow;
width:200px;
height:200px;

//离开的过度
.fade-leave-from
width:200px;
height:200px;
transform:rotate(360deg)

//离开中过度
.fade-leave-active
transition: all 1s linear;

//离开完成
.fade-leave-to
width:0px;
height:0px;

2.自定义过渡 class 类名

trasnsition props

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

自定义过度时间 单位毫秒

你也可以分别指定进入和离开的持续时间:

<transition :duration="1000">...</transition>


<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.​

<transition
leave-active-class="animate__animated animate__bounceInLeft"
enter-active-class="animate__animated animate__bounceInRight"
>
<div v-if="flag" class="box"></div>
</transition>

3.transition 生命周期8个

@before-enter="beforeEnter" //对应enter-from
@enter="enter"//对应enter-active
@after-enter="afterEnter"//对应enter-to
@enter-cancelled="enterCancelled"//显示过度打断
@before-leave="beforeLeave"//对应leave-from
@leave="leave"//对应enter-active
@after-leave="afterLeave"//对应leave-to
@leave-cancelled="leaveCancelled"//离开过度打断

当只用 javascript 过渡的时候,在 ​enter 和 ​leave​ 钩子中必须使用 ​done​ 进行回调

结合gsap 动画库使用 ​​GreenSock​

const beforeEnter = (el: Element) => 
console.log(进入之前from, el);

const Enter = (el: Element,done:Function) =>
console.log(过度曲线);
setTimeout(()=>
done()
,3000)

const AfterEnter = (el: Element) =>
console.log(to);

4.appear

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

appear-active-class=""
appear-from-class=""
appear-to-class=""
appear

以上是关于(transition动画组件)的主要内容,如果未能解决你的问题,请参考以下文章

Vue3过度和动画

Vue动画操作

vue怎么给路由切换时添加动画

vue2.0过度动画

基于 React 实现一个 Transition 过渡动画组件

vue笔记四