Vue中CSS動畫原理的實(shí)現(xiàn)
下面這段代碼,是點(diǎn)擊按鈕實(shí)現(xiàn)hello world顯示與隱藏
<div id="root">
<div v-if="show">hello world</div>
<button @click="handleClick">按鈕</button>
</div>
let vm = new Vue({
el: '#root',
data: {
show:true
},
methods: {
handleClick(){
this.show = !this.show
}
}
})
此時(shí)有一個需求,希望是在顯示與隱藏時(shí),能實(shí)現(xiàn)漸隱漸現(xiàn)的動畫效果。
<div id="root">
<transition name="fade">
<div v-if="show">hello world</div>
</transition>
<button @click="handleClick">按鈕</button>
</div>
let vm = new Vue({
el: '#root',
data: {
show:true
},
methods: {
handleClick(){
this.show = !this.show
}
}
})
如果希望hello world有一個動畫效果的話,需要在外面套一層transition標(biāo)簽,意思它包裹的內(nèi)容,有一個動畫效果,可以給它一個名字name="fade"。
enter
當(dāng)一個元素被transition標(biāo)簽包裹之后,Vue 會自動的分析元素的css樣式,然后構(gòu)建動畫流程

在動畫還沒有執(zhí)行的一瞬間,Vue 會幫我們在dom標(biāo)簽上添加兩個class,分別是fade-enter、fade-enter-active。
當(dāng)動畫第一幀執(zhí)行結(jié)束之后,transition這個標(biāo)簽分析過,里面有一個動畫效果,Vue 會在動畫運(yùn)行到第二幀的時(shí)候,會將dom標(biāo)簽上v-enter的class刪除,再添加一個v-enter-to的class。
接著動畫會繼續(xù)執(zhí)行,執(zhí)行到結(jié)束的一瞬間,Vue 會干一件事,它會把之前添加的v-enter-to和v-enter-active都刪除,
.fade-enter{
opacity: 0;
}
.fade-enter-active{
transition: opacity 3s;
}
<div id="root">
<transition name="fade">
<div v-if="show">hello world</div>
</transition>
<button @click="handleClick">按鈕</button>
</div>
let vm = new Vue({
el: '#root',
data: {
show:true
},
methods: {
handleClick(){
this.show = !this.show
}
}
})
我們只需要在css中給fade-enter和fade-enter-active分別寫上樣式就行了。這里要注意的是 Vue 中默認(rèn)以v開頭,如:v-enter,transition加個name屬性,就可以用name屬性值做開頭,如:fade-enter。
現(xiàn)在這里兩個class的意思是:
動畫還沒執(zhí)行時(shí),就已經(jīng)有fade-enter,fade-enter-active,動畫第一幀運(yùn)行時(shí)fade-enter就會被移除,css效果opacity: 0就會變成opacity: 1,直到動畫執(zhí)行完fade-enter-active才會被移除,這期間它用transition對opacity進(jìn)行監(jiān)控,需要3s才能完成。

leave
隱藏的動畫流程:
隱藏的第一個瞬間時(shí),Vue 會在dom上添加兩個class,分別是v-leave和v-leave-active
運(yùn)行到第二幀時(shí),Vue 會將v-leave移除,再添加一個v-leave-to
接著動畫會繼續(xù)執(zhí)行,執(zhí)行到結(jié)束的一瞬間,Vue 會把之前添加的v-leave-to和v-leave-active都刪除。
.fade-leave-to{
opacity: 0;
}
.fade-leave-active{
transition: opacity 3s;
}
<div id="root">
<transition name="fade">
<div v-if="show">hello world</div>
</transition>
<button @click="handleClick">按鈕</button>
</div>
let vm = new Vue({
el: '#root',
data: {
show:true
},
methods: {
handleClick(){
this.show = !this.show
}
}
})
為什么加了這兩個css動畫效果就出來了呢?
從動畫執(zhí)行的第一個瞬間,到動畫執(zhí)行完畢,fade-leave-active這個class都存在。也就是在動畫運(yùn)行過程中,我要時(shí)刻監(jiān)聽div的opacity,一旦opacity發(fā)生變化,我要讓讓他在3s內(nèi)執(zhí)行完畢。
在第一個瞬間fade-leave的opacity為1,就是顯示狀態(tài);第二個瞬間opacity為0了,此時(shí)要給它添加一個fade-leave-to的class,而fade-leave-active一直在監(jiān)聽opacity的變化,一旦opacity發(fā)生變化,會讓它在3s內(nèi)完成
自定義class
如果我不想用 Vue 提供的這六個class,我想自定義一個class,該怎么實(shí)現(xiàn)呢?
.active,.leave{
transition: opacity 3s;
}
Vue 給我們提供了一個自定義的屬性的方法,使用enter-active-class就能自定義一個enter類;使用leave-active-class就用自定義一個leave類。
<transition name="fade" enter-active-class="active" leave-active-class="leave" <div v-if="show">hello world</div> </transition>
利用這個特性,在項(xiàng)目中需使用復(fù)雜的css樣式時(shí),就可以引入第三方css樣式庫,這里介紹一個animate.css的庫。
使用第三方庫(animate.css),需要注意兩點(diǎn):
- 必須使用自定義class的方式
- 自定義class中必須有一個animated的class
<transition name="fade" enter-active-class="animated swing" leave-active-class="animated shake" <div v-if="show">hello world</div> </transition>
上面是按鈕點(diǎn)擊了才會出現(xiàn)動畫效果,但此時(shí)需求想要實(shí)現(xiàn)一入場就有動畫效果該怎么實(shí)現(xiàn)呢?
<transition name="fade" appear // 加上 appear 屬性 enter-active-class="animated swing" leave-active-class="animated shake" appear-active-class="animated swing" //使用自定義屬性 appear-active-class 就可以實(shí)現(xiàn) <div v-if="show">hello world</div> </transition>
如需要在一進(jìn)入就有動畫,需要借助兩個自定義屬性:appear、appear-active-class來實(shí)現(xiàn),看上面代碼。
過渡transition和動畫animation同時(shí)使用
當(dāng)同時(shí)使用transition和animation動畫時(shí),動畫時(shí)長是由誰來確定呢?
Vue 提供了可手動設(shè)置,看下面代碼
<transition name="fade" type="transition" //可手動設(shè)置動畫時(shí)長以 transition 為準(zhǔn) appear enter-active-class="animated swing" leave-active-class="animated shake" appear-active-class="animated swing" <div v-if="show">hello world</div> </transition>
在transition標(biāo)簽中,可以使用type屬性,它的用途是:如果同時(shí)有transition和animation時(shí),此時(shí)將type設(shè)置為transition,它就以transition動畫時(shí)長為準(zhǔn)。
回到代碼,現(xiàn)在需要自己定義動畫的時(shí)長,該怎么實(shí)現(xiàn)呢?
<transition name="fade" :duration="10000" //動畫總時(shí)長為 10s appear enter-active-class="animated swing" leave-active-class="animated shake" appear-active-class="animated swing" <div v-if="show">hello world</div> </transition>
Vue 提供了duration的屬性,可以自定義動畫時(shí)長。
這個自定義動畫時(shí)長,還可以設(shè)置的復(fù)雜一點(diǎn):
<transition name="fade"
:duration="{enter:5000,leave:10000}" //可分別設(shè)置 enter 動畫時(shí)長和 leave 動畫時(shí)長
appear
enter-active-class="animated swing"
leave-active-class="animated shake"
appear-active-class="animated swing"
<div v-if="show">hello world</div>
</transition>
最后
在transition標(biāo)簽中中不光v-if能控制顯示隱藏,v-show也能控制顯示隱藏,甚至動態(tài)組件也行。只要在transition中標(biāo)簽中動畫發(fā)生變化,都會有一個過渡效果
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue mint-ui 實(shí)現(xiàn)省市區(qū)街道4級聯(lián)動示例(仿淘寶京東收貨地址4級聯(lián)動)
本篇文章主要介紹了vue mint-ui 實(shí)現(xiàn)省市區(qū)街道4級聯(lián)動(仿淘寶京東收貨地址4級聯(lián)動),非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-10-10
vue中g(shù)et和post請求的區(qū)別點(diǎn)總結(jié)
在本篇文章里小編給大家分享的是一篇關(guān)于vue中g(shù)et和post請求的區(qū)別點(diǎn)總結(jié)內(nèi)容,對此有興趣的朋友們可以跟著學(xué)習(xí)下。2021-12-12
Vue.js結(jié)合SortableJS實(shí)現(xiàn)樹形數(shù)據(jù)拖拽
本文主要介紹了Vue.js結(jié)合SortableJS實(shí)現(xiàn)樹形數(shù)據(jù)拖拽,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
vue項(xiàng)目回到頂部的兩種超簡單實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目回到頂部的兩種超簡單實(shí)現(xiàn)方法,?頁面切換回到頂部是一個很常見的功能,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10
詳解基于iview-ui的導(dǎo)航欄路徑(面包屑)配置
這篇文章主要介紹了詳解基于iview-ui的導(dǎo)航欄路徑(面包屑)配置,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02
Vue cli+mui 區(qū)域滾動的實(shí)例代碼
下面小編就為大家分享一篇Vue cli+mui 區(qū)域滾動的實(shí)例代碼,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01
Vue3?中路由Vue?Router?的使用實(shí)例詳解
vue-router是vue.js官方給出的路由解決方案,能夠輕松的管理SPA項(xiàng)目中組件的切換,這篇文章主要介紹了Vue3?中路由Vue?Router?的使用,需要的朋友可以參考下2023-02-02

