Vue3之元素和組件的動畫切換實現(xiàn)示例詳解
前言
當(dāng)我們使用某個軟件或者網(wǎng)站完成一些交互的時候,會發(fā)現(xiàn)做得很好的網(wǎng)站和軟件都少不了動畫的潤色,完成的功能都是從一個界面跳轉(zhuǎn)到另一個界面,但是加動畫和不加動畫完全是兩種不同的體驗,而且動畫還可以遮住一些缺陷,比如相機預(yù)覽從16:9切換到4:3時會出現(xiàn)黑邊的情況,這時加一個轉(zhuǎn)場動畫,用戶就不會看到這個黑邊了,同樣在網(wǎng)站開發(fā)中如果說加載的另一個頁面網(wǎng)絡(luò)不太好時,我們可以使用一個加載動畫,讓用戶感覺當(dāng)前系統(tǒng)仍然正常。不會出現(xiàn)“卡死”的假象,本文我們就一起看下元素和組件之間的切換動畫如何實現(xiàn)
實例解析
元素間的動畫切換
元素之間的動畫切換指的是兩個dom元素之間的切換,比如一個div消失,另一個div顯示,消失對應(yīng)著漸出的效果,顯示對應(yīng)漸入的效果,本例我們以兩個div,一個顯示hello world,另一個顯示bye world,然后使用一個按鈕控制動畫的切換,代碼如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>元素切換動畫的實現(xiàn)</title>
<style>
.v-enter-from{
opacity: 0;
}
.v-enter-active{
transition: opacity 1s ease-in;
}
.v-enter-to{
opacity: 1;
}
.v-leave-from{
opacity: 1;
}
.v-leave-active{
transition:opacity 1s ease-in
}
.v-leave-to{
opacity: 0;
}
</style>
<script src="https://unpkg.com/vue@next"></script>
</head>
<body>
<div id="root"></div>
</body>
<script>
const app = Vue.createApp({
data() {
return {
show:false
}
},
methods: {
handleClick(){
this.show = !this.show;
}
},
template:
`
<transition mode="out-in" appear>
<div v-if="show">hello world </div>
<div v-else="show" >bye world </div>
</transition>
<button @click="handleClick">switch</button>
`
});
const vm = app.mount('#root');
</script>
如上面的代碼所示,我們使用CSS定義好漸入和漸出的效果,然后將我們要做動畫的div放到<transition></transition>標(biāo)簽之間,使用一個Boolean變量show控制元素的顯示和隱藏,當(dāng)我們點擊按鈕的時候,執(zhí)行handleClick函數(shù),將show變量取反,達到切換的效果。 在代碼中我們還看到了在transition標(biāo)簽上使用了一個mode="out-in",這個mode的取值其實還有一個是mode="in-out",兩者的區(qū)別如下:
mode="out-in": 表示兩個元素切換的時候,當(dāng)前的元素先消失,待顯示的元素再顯示 mode="in-out":表示兩個元素切換的時候,待顯示的元素先顯示,當(dāng)前的元素再消失
讀者可以將這兩個屬性都試試,看下效果,印象會更深
在代碼中我們看到有一個屬性appear,這個屬性的意思是當(dāng)我們在瀏覽器中打開界面的時候執(zhí)行動畫,否則頁面在加載的時候沒有動畫
組件間的動畫切換
在Vue中我們更多的會使用組件的方式 ,其實組件之間也是可以做動畫切換的實現(xiàn)的,這里我們可以把上面的例子改造下,以動態(tài)組件的方式實現(xiàn)下上面元素間切換的動畫效果,代碼如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>組件間切換動畫的實現(xiàn)</title>
<style>
.v-enter-from{
opacity: 0;
}
.v-enter-active{
transition: opacity 1s ease-in;
}
.v-enter-to{
opacity: 1;
}
.v-leave-from{
opacity: 1;
}
.v-leave-active{
transition:opacity 1s ease-in
}
.v-leave-to{
opacity: 0;
}
</style>
<script src="https://unpkg.com/vue@next"></script>
</head>
<body>
<div id="root"></div>
</body>
<script>
// 多個單組件之間的動畫
const ComponentA = {
template:'<div>hello world</div>'
}
const ComponentB = {
template:'<div>bye world</div>'
}
const app = Vue.createApp({
data() {
return {
component:'component-a'
}
},
methods: {
handleClick(){
if(this.component === 'component-a'){
this.component = 'component-b';
}else{
this.component = 'component-a';
}
}
},
components:{
'component-a':ComponentA,
'component-b':ComponentB
},
// 動態(tài)組件的方式
template:
`
<transition mode="out-in" appear>
<component :is="component" />
</transition>
<button @click="handleClick">switch</button>
`
});
const vm = app.mount('#root');
</script>
前面的章節(jié)中我們已經(jīng)介紹了如何使用動態(tài)組件,上面的代碼中我們定義了兩個組件ComponentA和ComponentB,默認顯示ComponentA組件的內(nèi)容,當(dāng)點擊按鈕的時候,使用動畫切換到ComponentB,效果和元素間切換的動畫一模一樣。讀者可以下去實踐下,這里不多介紹。
總結(jié)
本文主要介紹了元素間和組件間動畫切換的實現(xiàn),本文的主要目的是介紹組件間和元素間可以使用動畫來切換,至于動畫,本文使用的是非常簡單的動畫,讀者若是想實現(xiàn)更復(fù)雜炫麗的動畫,請自行實現(xiàn)
以上就是Vue3之元素和組件的動畫切換實現(xiàn)示例詳解的詳細內(nèi)容,更多關(guān)于Vue3元素和組件動畫切換的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vue使用vuex實現(xiàn)首頁導(dǎo)航切換不同路由的方法
這篇文章主要介紹了vue使用vuex實現(xiàn)首頁導(dǎo)航切換不同路由的方法 ,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-05-05
Vue axios庫避免重復(fù)發(fā)送請求的示例介紹
Axios是一個基于promise的HTTP庫,可以用在瀏覽器和node.js中。axios是目前最優(yōu)秀的HTTP請求庫之一,我們封裝axios請求也是為了讓代碼看的更加清晰,后期好維護2023-02-02
Vue.js中用webpack合并打包多個組件并實現(xiàn)按需加載
對于現(xiàn)在前端插件的頻繁更新,我也是無力吐槽,但是既然入了前端的坑就得認嘛,所以多多少少要對組件化有點了解,下面這篇文章主要給大家介紹了在Vue.js中用webpack合并打包多個組件并實現(xiàn)按需加載的相關(guān)資料,需要的朋友可以參考下。2017-02-02
vue項目中如何配置env環(huán)境的實現(xiàn)
本文主要介紹了vue項目中如何配置env環(huán)境的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
vue監(jiān)聽瀏覽器網(wǎng)頁關(guān)閉和網(wǎng)頁刷新事件代碼示例
在前端開發(fā)中我們通常會遇到這樣的需求,用戶離開、刷新頁面前,修改數(shù)據(jù)未進行保存操作,需要提示框提醒用戶,這篇文章主要給大家介紹了關(guān)于vue監(jiān)聽瀏覽器網(wǎng)頁關(guān)閉和網(wǎng)頁刷新事件的相關(guān)資料,需要的朋友可以參考下2023-08-08

