细说vue的过渡动画
来源:互联网 发布:手机ai软件下载 编辑:程序博客网 时间:2024/05/20 01:44
在vue中,实现过渡动画一般是下面这样:
<transition name="fade"> <div></div></transition>
用一个transition对元素或者组件进行封装.
在过渡的时候,会有 4 个(CSS)类名在 enter/leave 的过渡中切换。
- v-enter: 定义进入过渡的开始状态。在元素被插入时生效,在下一个帧移除。
- v-enter-active: 定义进入过渡的结束状态。在元素被插入时生效,在 transition/animation 完成之后移除。
- v-leave: 定义离开过渡的开始状态。在离开过渡被触发时生效,在下一个帧移除。
- v-leave-active: 定义离开过渡的结束状态。在离开过渡被触发时生效,在 transition/animation 完成之后移除。
上面是官方文档的原话,但是这4个类名如何运用呢?下面看个例子
<transition name="fold"> <div v-show="show" class="example"></div></transition>css:.example { width: 100px; height: 100px; transform: translate3d(0, -100px, 0);}.fold-enter-active, .fold-leave-active { transition: all .5s;}.fold-enter, .fold-leave-active { transform: translate3d(0, 0, 0);}
当show = true时:
这里的fold-enter,是在元素显示的一瞬间被加入,然后瞬间被移除,在上面的例子中,example这个块状元素本来因为有了transform: translate3d(0, -100px, 0)
这个样式,所以被上移了100px,但是因为fold-enter,所以将example这个块状元素移到了原位,但是fold-enter因为瞬间就被移除掉了,所以这时候的元素的样式又变成了transform: translate3d(0, -100px, 0)
,但是这时候fold-enter-active这个样式就生效了,因为设置了transition: all .5s
,所以元素会在0.5s的时间内上移100px,在过渡动画结束之后,fold-enter-active这个类马上被移除.
当show = false时:
example不会马上消失,这个时候fold-leave-active这个类就起作用了,example这时的位置是在-100px,fold-leave-active定义的是过渡的结束状态:transform: translate3d(0, 0, 0);
,但是同时又设置了transition: all .5s
,所以这时元素会在0.5s的时间内下移100px.之后fold-leave-active被移除.
官网的一张图:
另外,还可以在动画中调用js钩子函数:
<transition v-on:before-enter="beforeEnter" v-on:enter="enter" v-on:after-enter="afterEnter" v-on:enter-cancelled="enterCancelled" v-on:before-leave="beforeLeave" v-on:leave="leave" v-on:after-leave="afterLeave" v-on:leave-cancelled="leaveCancelled"></transition>
不过用的不多,可以在methods中定义这些方法.
- 细说vue的过渡动画
- vue 动画过渡
- Vue之过渡动画
- Vue相关(过渡动画)
- vue过渡动画
- vue过渡动画
- Vue 动画(过渡)
- vue 简单动画过渡
- vue过渡动画实现原理
- Vue的过渡效果
- Vue的过渡效果
- Vue过渡(动画)- transition组件
- Vue过渡(动画)- transition组件
- Vue过渡(动画)- transition组件
- vue学习第9天,过渡 动画
- vue学习第10天,过渡 动画
- vue学习第11天,过渡 动画 过渡模式
- ViewPager的过渡动画
- 2017.1.20【初中部 】普及组模拟赛C组 鸡腿の游戏 题解
- NOI 2015 品酒大会
- 【16级第一周寒假作业B题】
- ARM之时钟体系
- hdu 线段树 (矩形面积并+离散化+二分查找)
- 细说vue的过渡动画
- View分发机制
- (转)量化策略:Ricequant迎新年50篇干货分享
- 51 NOD 1091 线段的重叠
- OpenJudge 2989 糖果
- CodeForces 444C - DZY Loves Colors(线段树)
- 树状数组(3)
- ORACLE中使用RAMA删除部分日志
- Codeforces 451D - Count Good Substrings(组合数学)