欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3之元素和組件的動(dòng)畫切換實(shí)現(xiàn)示例詳解

 更新時(shí)間:2023年04月04日 16:31:10   作者:時(shí)光劍客  
這篇文章主要為大家介紹了Vue3之元素和組件的動(dòng)畫切換實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

前言

當(dāng)我們使用某個(gè)軟件或者網(wǎng)站完成一些交互的時(shí)候,會(huì)發(fā)現(xiàn)做得很好的網(wǎng)站和軟件都少不了動(dòng)畫的潤(rùn)色,完成的功能都是從一個(gè)界面跳轉(zhuǎn)到另一個(gè)界面,但是加動(dòng)畫和不加動(dòng)畫完全是兩種不同的體驗(yàn),而且動(dòng)畫還可以遮住一些缺陷,比如相機(jī)預(yù)覽從16:9切換到4:3時(shí)會(huì)出現(xiàn)黑邊的情況,這時(shí)加一個(gè)轉(zhuǎn)場(chǎng)動(dòng)畫,用戶就不會(huì)看到這個(gè)黑邊了,同樣在網(wǎng)站開發(fā)中如果說(shuō)加載的另一個(gè)頁(yè)面網(wǎng)絡(luò)不太好時(shí),我們可以使用一個(gè)加載動(dòng)畫,讓用戶感覺當(dāng)前系統(tǒng)仍然正常。不會(huì)出現(xiàn)“卡死”的假象,本文我們就一起看下元素和組件之間的切換動(dòng)畫如何實(shí)現(xiàn)

實(shí)例解析

元素間的動(dòng)畫切換

元素之間的動(dòng)畫切換指的是兩個(gè)dom元素之間的切換,比如一個(gè)div消失,另一個(gè)div顯示,消失對(duì)應(yīng)著漸出的效果,顯示對(duì)應(yīng)漸入的效果,本例我們以兩個(gè)div,一個(gè)顯示hello world,另一個(gè)顯示bye world,然后使用一個(gè)按鈕控制動(dòng)畫的切換,代碼如下:

<!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>元素切換動(dòng)畫的實(shí)現(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定義好漸入和漸出的效果,然后將我們要做動(dòng)畫的div放到<transition></transition>標(biāo)簽之間,使用一個(gè)Boolean變量show控制元素的顯示和隱藏,當(dāng)我們點(diǎn)擊按鈕的時(shí)候,執(zhí)行handleClick函數(shù),將show變量取反,達(dá)到切換的效果。 在代碼中我們還看到了在transition標(biāo)簽上使用了一個(gè)mode="out-in",這個(gè)mode的取值其實(shí)還有一個(gè)是mode="in-out",兩者的區(qū)別如下:

mode="out-in": 表示兩個(gè)元素切換的時(shí)候,當(dāng)前的元素先消失,待顯示的元素再顯示 mode="in-out":表示兩個(gè)元素切換的時(shí)候,待顯示的元素先顯示,當(dāng)前的元素再消失

讀者可以將這兩個(gè)屬性都試試,看下效果,印象會(huì)更深

在代碼中我們看到有一個(gè)屬性appear,這個(gè)屬性的意思是當(dāng)我們?cè)跒g覽器中打開界面的時(shí)候執(zhí)行動(dòng)畫,否則頁(yè)面在加載的時(shí)候沒有動(dòng)畫

組件間的動(dòng)畫切換

在Vue中我們更多的會(huì)使用組件的方式 ,其實(shí)組件之間也是可以做動(dòng)畫切換的實(shí)現(xiàn)的,這里我們可以把上面的例子改造下,以動(dòng)態(tài)組件的方式實(shí)現(xiàn)下上面元素間切換的動(dòng)畫效果,代碼如下:

<!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>組件間切換動(dòng)畫的實(shí)現(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>
    // 多個(gè)單組件之間的動(dòng)畫
    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
        },
        // 動(dòng)態(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)介紹了如何使用動(dòng)態(tài)組件,上面的代碼中我們定義了兩個(gè)組件ComponentAComponentB,默認(rèn)顯示ComponentA組件的內(nèi)容,當(dāng)點(diǎn)擊按鈕的時(shí)候,使用動(dòng)畫切換到ComponentB,效果和元素間切換的動(dòng)畫一模一樣。讀者可以下去實(shí)踐下,這里不多介紹。

總結(jié)

本文主要介紹了元素間和組件間動(dòng)畫切換的實(shí)現(xiàn),本文的主要目的是介紹組件間和元素間可以使用動(dòng)畫來(lái)切換,至于動(dòng)畫,本文使用的是非常簡(jiǎn)單的動(dòng)畫,讀者若是想實(shí)現(xiàn)更復(fù)雜炫麗的動(dòng)畫,請(qǐng)自行實(shí)現(xiàn)

以上就是Vue3之元素和組件的動(dòng)畫切換實(shí)現(xiàn)示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Vue3元素和組件動(dòng)畫切換的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue使用vuex實(shí)現(xiàn)首頁(yè)導(dǎo)航切換不同路由的方法

    vue使用vuex實(shí)現(xiàn)首頁(yè)導(dǎo)航切換不同路由的方法

    這篇文章主要介紹了vue使用vuex實(shí)現(xiàn)首頁(yè)導(dǎo)航切換不同路由的方法 ,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • vue實(shí)現(xiàn)購(gòu)物車案例

    vue實(shí)現(xiàn)購(gòu)物車案例

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)購(gòu)物車案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • vue3項(xiàng)目目錄結(jié)構(gòu)示例詳解

    vue3項(xiàng)目目錄結(jié)構(gòu)示例詳解

    更好的了解項(xiàng)目的目錄結(jié)構(gòu),能更好的去開發(fā)項(xiàng)目,下面這篇文章主要給大家介紹了關(guān)于vue3項(xiàng)目目錄結(jié)構(gòu)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • Vue中引入json的三種方式總結(jié)

    Vue中引入json的三種方式總結(jié)

    這篇文章主要介紹了Vue中引入json的三種方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue axios庫(kù)避免重復(fù)發(fā)送請(qǐng)求的示例介紹

    Vue axios庫(kù)避免重復(fù)發(fā)送請(qǐng)求的示例介紹

    Axios是一個(gè)基于promise的HTTP庫(kù),可以用在瀏覽器和node.js中。axios是目前最優(yōu)秀的HTTP請(qǐng)求庫(kù)之一,我們封裝axios請(qǐng)求也是為了讓代碼看的更加清晰,后期好維護(hù)
    2023-02-02
  • Vue.js中用webpack合并打包多個(gè)組件并實(shí)現(xiàn)按需加載

    Vue.js中用webpack合并打包多個(gè)組件并實(shí)現(xiàn)按需加載

    對(duì)于現(xiàn)在前端插件的頻繁更新,我也是無(wú)力吐槽,但是既然入了前端的坑就得認(rèn)嘛,所以多多少少要對(duì)組件化有點(diǎn)了解,下面這篇文章主要給大家介紹了在Vue.js中用webpack合并打包多個(gè)組件并實(shí)現(xiàn)按需加載的相關(guān)資料,需要的朋友可以參考下。
    2017-02-02
  • vue2.0 如何在hash模式下實(shí)現(xiàn)微信分享

    vue2.0 如何在hash模式下實(shí)現(xiàn)微信分享

    這篇文章主要介紹了vue2.0 如何在hash模式下實(shí)現(xiàn)微信分享,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • vue項(xiàng)目中如何配置env環(huán)境的實(shí)現(xiàn)

    vue項(xiàng)目中如何配置env環(huán)境的實(shí)現(xiàn)

    本文主要介紹了vue項(xiàng)目中如何配置env環(huán)境的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • vue實(shí)現(xiàn)簡(jiǎn)易計(jì)算器功能

    vue實(shí)現(xiàn)簡(jiǎn)易計(jì)算器功能

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)簡(jiǎn)易計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • vue監(jiān)聽瀏覽器網(wǎng)頁(yè)關(guān)閉和網(wǎng)頁(yè)刷新事件代碼示例

    vue監(jiān)聽瀏覽器網(wǎng)頁(yè)關(guān)閉和網(wǎng)頁(yè)刷新事件代碼示例

    在前端開發(fā)中我們通常會(huì)遇到這樣的需求,用戶離開、刷新頁(yè)面前,修改數(shù)據(jù)未進(jìn)行保存操作,需要提示框提醒用戶,這篇文章主要給大家介紹了關(guān)于vue監(jiān)聽瀏覽器網(wǎng)頁(yè)關(guān)閉和網(wǎng)頁(yè)刷新事件的相關(guān)資料,需要的朋友可以參考下
    2023-08-08

最新評(píng)論