17.transition动画组件


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

条件渲染 (使用 v-if)

条件展示 (使用 v-show)

动态组件

组件根节点

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

1.过渡的类名

在进入/离开的过渡中,会有 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 被移除),在过渡/动画完成之后移除。

transition name='fade'>
  
//开始过度 .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

  • <font style="color:rgb(51, 51, 51);">enter-from-class</font>
  • <font style="color:rgb(51, 51, 51);">enter-active-class</font>
  • <font style="color:rgb(51, 51, 51);">enter-to-class</font>
  • <font style="color:rgb(51, 51, 51);">leave-from-class</font>
  • <font style="color:rgb(51, 51, 51);">leave-active-class</font>
  • <font style="color:rgb(51, 51, 51);">leave-to-class</font>
...
...

通过自定义 class 结合 css 动画库 animate css(官方文档 Animate.css )

// 安装库
npm install animate.css
// 引入
import 'animate.css'
<transition
  leave-active-class="animate__animated animate__bounceInLeft"
  enter-active-class="animate__animated animate__bounceInRight"
>
  <div v-if="flag" class="box"></div>
</transition>

3.trasion 的 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 过渡的时候,在 **<font style="color:rgb(77, 77, 77);">enter</font>****<font style="color:rgb(77, 77, 77);">leave</font>** 钩子中必须使用 **<font style="color:rgb(77, 77, 77);">done</font>** 进行回调

结合 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

文章作者:   leader755
版权声明:   本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 leader755 !
评论
 上一篇
16.keep-alive缓存组件 16.keep-alive缓存组件
内置组件 keep-alive有时候我们不希望组件被重新渲染影响使用体验;或者处于性能考虑,避免多次重复渲染降低性能。而是希望组件可以缓存下来,维持当前的状态。这时候就需要用到<font style="color:rgb(
2025-01-30 leader755
下一篇 
18.transition-group过度列表 18.transition-group过度列表
单个节点 多个节点,每次只渲染一个 那么怎么同时渲染整个列表,比如使用 v-for?在这种场景下,我们会使用 <transition-group> 组件。在我们深入例子之前,先了解关于这个组件的几个特点: 默认情况下
2025-01-30 leader755
  目录