Vue学习笔记 - 关于过渡效果的一些总结

虽然经常用Vue做提供的transition做动画效果,但是每次都要去官方文档看好几遍才能写,所以总结下加深理解:

过渡的类名

Vue提供了以下类名用于实现动画:

  • v-enter
  • v-enter-active
  • v-enter-to
  • v-leave
  • v-leave-active
  • v-leave-to

之前我对这些类名添加在元素身上的时机,理解是有误的导致写动画效果的时候,基本靠猜,下面说下我自己的理解:

一个完整的过渡效果流程:

  1. 元素未插入之前:

    • 元素未插入之前在v-enter和v-enter-active这两个类名就会添加到元素上。
  2. 元素插入后的下一帧:

    • 元素插入后的下一帧,v-enter这个类名就会被移除同时v-enter-to会被添加到元素上,如果v-enter中写了样式,如果过渡的时间足够长,你就会看到元素是以v-enter中定义的样式开始过渡的,可以理解v-enter是用于定义元素过渡开始的初始样式。
  3. 元素过渡效果结束

    • 元素过渡效果结束,v-enter-active和v-enter-to被移除,因为v-enter-active一直从元素的过渡开始直到过渡结束才会被移除,所以v-enter-active中常常用来定义元素的过渡效果。v-enter-active 和 v-enter-to不同的是v-enter-to是元素被插入后的下一帧才被添加,v-enter-active在元素插入前就存在了。(我试着将过渡时间写在v-enter-to中,效果看起来没什么区别)

    • 元素过渡效果结束之后,由于v-enter-to被移除了,所以元素会变为自身的样式,这也是我老是理解错的一点,我之前的理解是这样:

      v-enter -> v-enter-active -> v-enter-to(这里定义了元素过渡结束后的样式)

      这个理解是错的,其实是这样:

      v-enter, v-enter-active -> v-enter-active, v-enter-to -> 元素本身的样式

      如果定义了v-enter-to,v-enter-to中的样式和元素本身的样式不一样,而且元素本身样式中没有过渡效果相关的css,在过渡结束后元素的样式会突然从v-enter-to中的样式变成元素本身的样式,也可以将v-enter-to中的样式写的和元素本身一样,那么过渡结束后的变化就不会很突兀。一般的过渡都是从某个样式过渡到元素本身的样式,所以,v-enter-to一般是不写的。

  4. 元素被移除的过渡开始:

    • 元素被移除的过渡开始会添加v-leave,v-leave-active, v-leave-to类名,过渡开始的下一帧会v-leave被移除,按照我对v-enter的立即,v-leave应该也是元素移除过渡开始的初始样式,但是可能移除过渡开始的速度太快了,我自己测试的时候并没有看到定义在v-leave中的样式生效。v-leave-active和v-leave-to都会在过渡效果完成之后移除。离开的过渡流程大概是这样:

      v-leave, ,v-leave-active, v-leave-to -> v-leave-active, v-leave-to -> 元素被移除

综合上面得出的结论:

  1. v-enter, v-leave-to中的css一般相同,一个是进入时过渡(动画)的初始样式,一个是离开过渡(动画)结束时的样式。
  2. v-enter-active ,v-leave-active 中的css一般相同,一般都是用于定义过渡(动画)的过程时间,延迟和曲线函数。当然离开的过渡(动画)的过程时间,延迟和曲线函数和进入的可以是不同的。
  3. v-enter-to,v-leave一般不写,不写的原因是:按照一般的过渡效果(动画),进入的最后状态就是元素本身的样式,离开的最初状态也是元素本身的样式,所以是没有必要写的。(v-leave我自己是没有测试出效果。。。)

转载于:https://juejin.im/post/5c9e15176fb9a05e3f51e3bb

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值