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

Vue動態(tài)組件與異步組件超詳細講解

 更新時間:2023年03月16日 09:17:42   作者:時光劍客  
這篇文章主要介紹了Vue動態(tài)組件與異步組件,動態(tài)組件是根據(jù)數(shù)據(jù)的變化,可以隨時切換不同的組件,比如咱們現(xiàn)在要展示一個文本框和輸入框,我們想要根據(jù)我們data中定義的值去決定是顯示文本框還是輸入框

何為動態(tài)組件

動態(tài)組件是根據(jù)數(shù)據(jù)的變化,可以隨時切換不同的組件,比如咱們現(xiàn)在要展示一個文本框和輸入框,我們想要根據(jù)我們data中定義的值去決定是顯示文本框還是輸入框,如果用以前學的知識去做的話就是使用v-show的方式去做,雖然也能實現(xiàn),但是比較復雜,代碼也多了很多,這時候用動態(tài)組件能很好的解決這個問題

何為異步組件

異步組件可以以異步的方式加載組件,實際項目中我們可以把大型的項目拆分成許多小js文件,等使用時再組合,而且可以實現(xiàn)懶加載,有些組件暫時不需要展示給用戶的我們可以等用戶看到時再加載進來。

示例解析

動態(tài)組件

展示一個輸入框或者文本,通過一個按鈕,點擊后可以切換展示,比如當前展示文本,點擊按鈕就會變?yōu)檎故据斎肟颍a如下:

首先我們先定義兩個組件,一個展示輸入框,一個展示文本

  app.component('input-item',{
        template:`
            <input />
           `
    });
    app.component('common-item',{
        template:`<div>hello world</div>`
    });

定義一個currentItem變量用于控制組件的展示

data() {
        return {
            currentItem: 'input-item'
        }
    },

使用組件時使用component關鍵字 ,然后使用:is = "顯示具體組件的依賴數(shù)據(jù)(本例子中時currentItem)"的方式動態(tài)加載組件

  template: 
        `
        <keep-alive>
        <component :is="currentItem"/>
        </keep-alive>
        <button @click="handleClick">switch</button>
        `

keep-alive:組件切換時在組件中的值會被清掉,比如輸入框中的值,所以需要使用keep-alive來防止值被清理

定義點擊按鈕后執(zhí)行的方法,這個方法就是改變current Item的值,讓其顯示不同的組件

 methods: {
        handleClick(){
            if(this.currentItem === 'input-item'){
                this.currentItem = 'common-item';
            }else{
                this.currentItem = 'input-item';
            }
        }
    }

所有代碼:

<!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>動態(tài)組件</title>
    <script src="https://unpkg.com/vue@next"></script>
</head>
<body>
    <div id="root"></div>
</body>
<script>
 const app = Vue.createApp({
    data() {
        return {
            currentItem: 'input-item'
        }
    },
    methods: {
        handleClick(){
            if(this.currentItem === 'input-item'){
                this.currentItem = 'common-item';
            }else{
                this.currentItem = 'input-item';
            }
        }
    },
        template: 
        `
        <keep-alive>
        <component :is="currentItem"/>
        </keep-alive>
        <button @click="handleClick">switch</button>
        `
    });
    app.component('input-item',{
        template:`
            <input />
           `
    });
    app.component('common-item',{
        template:`<div>hello world</div>`
    });
    const vm = app.mount('#root');
</script>
</html>

異步組件

假如我們要展示一個文本,這個文本不會馬上展示,而是4秒后再展示

首先定義兩個組件,一個同步組件,一個異步組件

定義同步組件

 app.component('common-item',{
        template:`<div>hello world</div>`
    })

定義異步組件,使用Vue.defineAsyncComponent定義異步組件

 app.component('async-common-item',
 Vue.defineAsyncComponent(()=>{
        return new Promise((resolve,reject)=>{
            setTimeout(()=>{
                resolve({
                    template:`<div>this is an async component</div>`
                })
            },4000)  
        })
    }));

使用組件

 const app = Vue.createApp({
        template: 
        `
        <div>
            <common-item />
            <async-common-item />
        </div>
        `
    });

全部代碼:

<!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>異步組件</title>
    <script src="https://unpkg.com/vue@next"></script>
</head>
<body>
    <div id="root"></div>
</body>
<script>
 const app = Vue.createApp({
        template: 
        `
        <div>
            <common-item />
            <async-common-item />
        </div>
        `
    });
    app.component('common-item',{
        template:`<div>hello world</div>`
    })
    // 異步組件:可以通過異步組件的方式動態(tài)加載組件,可以把大型項目拆分成許多的小js 文件,使用時再組合
    app.component('async-common-item',
        Vue.defineAsyncComponent(()=>{
        return new Promise((resolve,reject)=>{
            setTimeout(()=>{
                resolve({
                    template:`<div>this is an async component</div>`
                })
            },4000)        
        })
    }));
    const vm = app.mount('#root');
</script>
</html>

總結(jié)

本文主要是簡單介紹了動態(tài)組件和異步組件的定義及使用的方法,動態(tài)組件是可以讓我們使用者通過一定的條件決定展示哪個組件,而異步組件可以讓我們實現(xiàn)組件懶加載的功能,使大型項目可以拆成許多小js文件,使用時再組合,非常方便

到此這篇關于Vue動態(tài)組件與異步組件超詳細講解的文章就介紹到這了,更多相關Vue動態(tài)組件與異步組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue使用leafLet方式(繪圖工具)

    vue使用leafLet方式(繪圖工具)

    這篇文章主要介紹了vue使用leafLet方式(繪圖工具),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • 動態(tài)Axios的配置步驟詳解

    動態(tài)Axios的配置步驟詳解

    這篇文章主要給大家分享介紹了關于動態(tài)Axios的配置步驟,文中通過示例代碼介紹的非常詳細,通過這個教程大家可以很方便的實現(xiàn)動態(tài)Axios的配置,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧。
    2018-01-01
  • 詳解vue中組件參數(shù)

    詳解vue中組件參數(shù)

    這篇文章主要介紹了vue中組件參數(shù),本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-07-07
  • reactive readonly嵌套對象轉(zhuǎn)換功能實現(xiàn)詳解

    reactive readonly嵌套對象轉(zhuǎn)換功能實現(xiàn)詳解

    這篇文章主要為大家介紹了reactive readonly嵌套對象轉(zhuǎn)換功能實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • vue-cli配置使用Vuex的全過程記錄

    vue-cli配置使用Vuex的全過程記錄

    這篇文章主要給大家介紹了關于vue-cli配置使用Vuex的相關資料,Vuex 是一個專為 Vue.js 應用程序開發(fā)的狀態(tài)管理模式,本介紹的非常詳細,需要的朋友可以參考下
    2021-07-07
  • Vue3設計思想及響應式源碼解析

    Vue3設計思想及響應式源碼解析

    這篇文章主要為大家介紹了Vue3設計思想及響應式源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • 一起來學習Vue的生命周期

    一起來學習Vue的生命周期

    這篇文章主要為大家詳細介紹了Vue的生命周期,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • vue項目實現(xiàn)局部全屏完整代碼

    vue項目實現(xiàn)局部全屏完整代碼

    最近需要做一個全屏功能,所以這里給大家總結(jié)下,這篇文章主要給大家介紹了關于vue項目實現(xiàn)局部全屏的相關資料,需要的朋友可以參考下
    2023-09-09
  • Vue使用Clipboard.JS在h5頁面中復制內(nèi)容實例詳解

    Vue使用Clipboard.JS在h5頁面中復制內(nèi)容實例詳解

    在本篇文章里小編給大家整理了關于Vue使用Clipboard.JS在h5頁面中復制內(nèi)容以及相關知識點內(nèi)容,需要的朋友們可以學習下。
    2019-09-09
  • vue強制刷新組件的方法示例

    vue強制刷新組件的方法示例

    這篇文章主要介紹了vue強制刷新組件的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-02-02

最新評論