Vue中CSS动画原理的实现
下面这段代码,是点击按钮实现hello world显示与隐藏
成都创新互联公司专业为企业提供绵阳网站建设、绵阳做网站、绵阳网站设计、绵阳网站制作等企业网站建设、网页设计与制作、绵阳企业网站模板建站服务,10多年绵阳做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
let vm = new Vue({ el: '#root', data: { show:true }, methods: { handleClick(){ this.show = !this.show } } })hello world
此时有一个需求,希望是在显示与隐藏时,能实现渐隐渐现的动画效果。
let vm = new Vue({ el: '#root', data: { show:true }, methods: { handleClick(){ this.show = !this.show } } }) hello world
如果希望hello world有一个动画效果的话,需要在外面套一层transition标签,意思它包裹的内容,有一个动画效果,可以给它一个名字name="fade"。
enter
当一个元素被transition标签包裹之后,Vue 会自动的分析元素的css样式,然后构建动画流程
在动画还没有执行的一瞬间,Vue 会帮我们在dom标签上添加两个class,分别是fade-enter、fade-enter-active。
当动画第一帧执行结束之后,transition这个标签分析过,里面有一个动画效果,Vue 会在动画运行到第二帧的时候,会将dom标签上v-enter的class删除,再添加一个v-enter-to的class。
接着动画会继续执行,执行到结束的一瞬间,Vue 会干一件事,它会把之前添加的v-enter-to和v-enter-active都删除,
.fade-enter{ opacity: 0; } .fade-enter-active{ transition: opacity 3s; }let vm = new Vue({ el: '#root', data: { show:true }, methods: { handleClick(){ this.show = !this.show } } }) hello world
我们只需要在css中给fade-enter和fade-enter-active分别写上样式就行了。这里要注意的是 Vue 中默认以v开头,如:v-enter,transition加个name属性,就可以用name属性值做开头,如:fade-enter。
现在这里两个class的意思是:
动画还没执行时,就已经有fade-enter,fade-enter-active,动画第一帧运行时fade-enter就会被移除,css效果opacity: 0就会变成opacity: 1,直到动画执行完fade-enter-active才会被移除,这期间它用transition对opacity进行监控,需要3s才能完成。
leave
隐藏的动画流程:
隐藏的第一个瞬间时,Vue 会在dom上添加两个class,分别是v-leave和v-leave-active
运行到第二帧时,Vue 会将v-leave移除,再添加一个v-leave-to
接着动画会继续执行,执行到结束的一瞬间,Vue 会把之前添加的v-leave-to和v-leave-active都删除。
.fade-leave-to{ opacity: 0; } .fade-leave-active{ transition: opacity 3s; }let vm = new Vue({ el: '#root', data: { show:true }, methods: { handleClick(){ this.show = !this.show } } }) hello world
为什么加了这两个css动画效果就出来了呢?
从动画执行的第一个瞬间,到动画执行完毕,fade-leave-active这个class都存在。也就是在动画运行过程中,我要时刻监听div的opacity,一旦opacity发生变化,我要让让他在3s内执行完毕。
在第一个瞬间fade-leave的opacity为1,就是显示状态;第二个瞬间opacity为0了,此时要给它添加一个fade-leave-to的class,而fade-leave-active一直在监听opacity的变化,一旦opacity发生变化,会让它在3s内完成
自定义class
如果我不想用 Vue 提供的这六个class,我想自定义一个class,该怎么实现呢?
.active,.leave{ transition: opacity 3s; }
Vue 给我们提供了一个自定义的属性的方法,使用enter-active-class就能自定义一个enter类;使用leave-active-class就用自定义一个leave类。
hello world
利用这个特性,在项目中需使用复杂的css样式时,就可以引入第三方css样式库,这里介绍一个animate.css的库。
使用第三方库(animate.css),需要注意两点:
- 必须使用自定义class的方式
- 自定义class中必须有一个animated的class
hello world
上面是按钮点击了才会出现动画效果,但此时需求想要实现一入场就有动画效果该怎么实现呢?
hello world