Vue 在插入、更新或者移除 DOM (就是添加、移除元素节点) 时,提供多种不同方式的应用过渡效果。
包括以下工具:
- 在 CSS 过渡 和动画中自动应用 class (在 <style> 中定义 css 效果)
- 在过渡钩子函数中使用 JavaScript 直接操作 DOM (methods 里面直接定义函数,并在<transition> 组件中用v-on 绑定 过渡状态 和methods 里的函数)
- 可以配合使用第三方 CSS 动画库,如 Animate.css
- 可以配合使用第三方 JavaScript 动画库,如 Velocity.js
过渡的类名:
在进入/离开的过渡中,会有 6 个 class 切换。
1. v-enter
:定义进入过渡的开始状态。在元素被插入之前生效,在元素被插入之后的下一帧移除。
2. v-enter-active
:定义进入过渡生效时的状态。在整个进入过渡的阶段中应用,在元素被插入之前生效,在过渡/动画完成之后移除。这个类可以被用来定义进入过渡的过程时间,延迟和曲线函数。
3. v-enter-to
: 2.1.8版及以上 定义进入过渡的结束状态。在元素被插入之后下一帧生效 (与此同时v-enter
被移除),在过渡/动画完成之后移除。
4. v-leave
: 定义离开过渡的开始状态。在离开过渡被触发时立刻生效,下一帧被移除。
5. v-leave-active
:定义离开过渡生效时的状态。在整个离开过渡的阶段中应用,在离开过渡被触发时立刻生效,在过渡/动画完成之后移除。这个类可以被用来定义离开过渡的过程时间,延迟和曲线函数。
6. v-leave-to
: 2.1.8版及以上 定义离开过渡的结束状态。在离开过渡被触发之后下一帧生效 (与此同时v-leave
被删除),在过渡/动画完成之后移除。
过渡的名字 name:
如果你使用一个前没有名字的
<transition>
,则v-
是这些类名的默认缀。如果你使用了<transition name="my-transition">
,那么v-enter
会替换为my-transition-enter
。
动画animation 与过渡 transition 的区别
在动画中
v-enter
类名在节点插入 DOM 后不会立即删除,而是在animationend
事件触发时删除。
使用过渡 transtion和 动画animation 的3种方式:
一、使用CSS (使用 name 特性,绑类名 css 样式)
1. 在<style>标签里设置过渡的类的样式(6 个 class:v-enter-active,v-enter,v-enter-to;v-leave,v-leave-to,v-leave-active)
2. 在 <transition> 组件里 使用 name 特性,绑类名 css 样式(例如: <transition name="change">,<style> </style> 里面的样式名应绑定为 change-enter-active,change-enter,change-enter-to;change-leave,change-leave-to,change-leave-active)。(例如:<transition name="change">)
<style> .change-enter{ color:red; font-size:20px; transition:2s; } .change-enter-to{ color:blue; font-size:58px; transition:5s; } .change-enter-active{ transition-timing-function:ease; } .change-leave-active{ color:yellow; font-size:2px; transition:3s;} </style>
</