Vue中Mixin&extends的詳細使用教程

認識Mixin

目前我們使用組件化開發方式來開發應用程序,但是在不同組件之間存在一些相同的代碼邏輯,此時我們希望對相同的代碼邏輯進行抽取。

在vue2和vue3中都支持使用Mixin來解決,Mixin提供瞭一種非常靈活的方式,來分發Vue組件中的可復用功能,一個Mixin對象可以包含任何組件選項,當組件使用Mixin對象時,所有Mixin對象的選項將被 混合 進入該組件本身的選項中。

官方定義Mixin

Mixin 提供瞭一種非常靈活的方式,來分發 Vue 組件中的可復用功能。一個 mixin 對象可以包含任意組件選項。當組件使用 mixin 對象時,所有 mixin 對象的選項將被“混合”進入該組件本身的選項。

項目中如何使用Mixin

在src文件夾下創建一個mixins文件夾

在demomixins.js文件下

export default {
    data() {
        return {
            msg:'mixins 中的data'
        }
    },
    mounted() {
        console.log('mixins 中的mounted');
    },
    methods:{
        foo() {
            console.log('mixins 中的methods');
        }
    },
    computed:{
        message() {
            return 'mixin 中的computed'
        }
    }
}

在Home.vue文件下

<template>
    <div class='home'>
        {{msg}}<br>
        {{message}}<br>
        <button @click="foo">點擊按鈕</button>
    </div>
</template>

<script>
// 導入js文件
import demomixins from '@/mixins/demomixins.js'
export default {
    name:'Home',
    data() {
        return {
        };
    },
    mixins:[demomixins],	// 混入demomixins對象
    mounted() {
    },
    methods: {},
    components:{},
};
</script>

雖然我們沒有在home.vue中定義msg變量、message計算屬性、foo方法,但是頁面中可以顯示。

Mixin的合並規則

如果Mixin對象中的選項和組件對象中的選項發生瞭沖突,那麼Vue會如何操作呢?

<template>
    <div class='home'>
        {{msg}}<br>
        {{message}}<br>
        <button @click="foo">點擊按鈕</button>
    </div>
</template>

<script>
// 導入
import demomixins from '@/mixins/demomixins.js'
export default {
    name:'Home',
    data() {
        return {
            msg:'home 中的data'
        };
    },
    mixins:[demomixins],
    mounted() {
        console.log('home 中的mounted');
    },
    methods:{
        foo() {
            console.log('home 中的methods');
        }
    },
    computed:{
        message() {
            return 'home 中的computed'
        }
    }
};
</script>

以上我們可以看出:

混入的對象中的msg屬性,和組件的msg屬性沖突,以組件的值優先。組件中沒有的屬性,混入對象中的生效。

同名鉤子函數將會合並成一個數組,都會調用,混入函數先調用

值為對象的選項,如methods,computed等,將會合並為一個新對象,如果鍵名沖突,組件的值優先

全局混入Mixin

如果組件中的某些選項,是所有的組件都需要擁有的,那麼這個時候我們可以使用全局的mixin。一旦註冊,那麼全局混入的選項將會影響每一個組件

const app = createApp(App)
app.mixin({
    data() {
        return {
            msg:'global 中的data'
        }
    },
})

官方定義extends

允許一個組件擴展到另一個組件,且繼承該組件選項。

extends類似於mixin,相當於繼承,但是隻是繼承options Api中的內容,不繼承template模板。

項目中使用extends

在components創建一個組件my.vue

<script>
export default {
    data() {
        return {
            msg:'uu盤'
        };
    }
};
</script>

在Home.vue文件下

<template>
    <div class='home'>
        {{msg}}
    </div>
</template>

<script>
// 導入
import my from '@/components/my'
export default {
    name:'Home',
    extends:my,
    data() {
        return {
            
        };
    },
};
</script>

在開發中extends用的非常少,在Vue2中比較推薦大傢使用Mixin,而在Vue3中推薦使用Composition API。

總結

到此這篇關於Vue中Mixin&amp;extends詳細使用的文章就介紹到這瞭,更多相關Vue中Mixin&amp;extends使用內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: