transition过渡属性
属性 | 描述 | 值 | 举例 | transition | 简写,包含4个过度属性 | | transition:width? 1s? linear? 1s; | transition-property | css属性的名称 | all:所有属性都将获得过渡效果。 | transition-property:height; | transition-duration | 过渡效果花费的时间,默认0 | | transition-duration:2s; | transition-timing-function | 过渡效果的时间曲线。默认是 "ease"。 | linear:规定以相同速度开始至结束的过渡效果(等于 cubic-bezier(0,0,1,1))。 ease:规定慢速开始,然后变快,然后慢速结束的过渡效果(cubic-bezier(0.25,0.1,0.25,1)) ease-in:规定以慢速开始的过渡效果(等于 cubic-bezier(0.42,0,1,1)) ease-out:规定以慢速结束的过渡效果(等于 cubic-bezier(0,0,0.58,1)) ease-in-out:规定以慢速开始和结束的过渡效果(等于 cubic-bezier(0.42,0,0.58,1)) cubic-bezier(n,n,n,n):在 cubic-bezier 函数中定义自己的值。可能的值是 0 至 1 之间的数值 | transition-timing-function: linear; | transition-delay | 过渡效果何时开始。默认是 0 | | transition-delay: 2s; |
Transition是一个内置组件,API
触发条件
- 由?
v-if ?所触发的切换 - 由?
v-show ?所触发的切换 - 由特殊元素?
<component> ?切换的动态组件
?css过渡class
-
v-enter-from :进入动画的起始状态。在元素插入之前添加,在元素插入完成后的下一帧移除。 -
v-enter-active :进入动画的生效状态。应用于整个进入动画阶段。在元素被插入之前添加,在过渡或动画完成之后移除。这个 class 可以被用来定义进入动画的持续时间、延迟与速度曲线类型。 -
v-enter-to :进入动画的结束状态。在元素插入完成后的下一帧被添加 (也就是?v-enter-from ?被移除的同时),在过渡或动画完成之后移除。 -
v-leave-from :离开动画的起始状态。在离开过渡效果被触发时立即添加,在一帧后被移除。 -
v-leave-active :离开动画的生效状态。应用于整个离开动画阶段。在离开过渡效果被触发时立即添加,在过渡或动画完成之后移除。这个 class 可以被用来定义离开动画的持续时间、延迟与速度曲线类型。 -
v-leave-to :离开动画的结束状态。在一个离开动画被触发后的下一帧被添加 (也就是?v-leave-from ?被移除的同时),在过渡或动画完成之后移除。
自定义过渡class
enter-from-class enter-active-class enter-to-class leave-from-class leave-active-class leave-to-class
<Transition
name="custom-classes"
enter-active-class="animate__animated animate__tada"
leave-active-class="animate__animated animate__bounceOutRight"
>
<p v-if="show">hello</p>
</Transition>
js钩子
在使用仅由 JavaScript 执行的动画时,最好是添加一个?:css="false" ?prop。这显式地向 Vue 表明可以跳过对 CSS 过渡的自动探测。除了性能稍好一些之外,还可以防止 CSS 规则意外地干扰过渡效果。
<Transition
@before-enter="onBeforeEnter"
@enter="onEnter"
@after-enter="onAfterEnter"
@enter-cancelled="onEnterCancelled"
@before-leave="onBeforeLeave"
@leave="onLeave"
@after-leave="onAfterLeave"
@leave-cancelled="onLeaveCancelled"
>
<!-- ... -->
</Transition>
export default {
// ...
methods: {
// 在元素被插入到 DOM 之前被调用
// 用这个来设置元素的 "enter-from" 状态
onBeforeEnter(el) {},
// 在元素被插入到 DOM 之后的下一帧被调用
// 用这个来开始进入动画
onEnter(el, done) {
// 调用回调函数 done 表示过渡结束
// 如果与 CSS 结合使用,则这个回调是可选参数
done()
},
// 当进入过渡完成时调用。
onAfterEnter(el) {},
onEnterCancelled(el) {},
// 在 leave 钩子之前调用
// 大多数时候,你应该只会用到 leave 钩子
onBeforeLeave(el) {},
// 在离开过渡开始时调用
// 用这个来开始离开动画
onLeave(el, done) {
// 调用回调函数 done 表示过渡结束
// 如果与 CSS 结合使用,则这个回调是可选参数
done()
},
// 在离开过渡完成、
// 且元素已从 DOM 中移除时调用
onAfterLeave(el) {},
// 仅在 v-show 过渡中可用
onLeaveCancelled(el) {}
}
}
|