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

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

 更新時間:2022年02月23日 10:58:08   作者:uu盤  
vue提供了mixin、extends配置項,最近使用中發(fā)現(xiàn)很好用,下面這篇文章主要給大家介紹了關(guān)于Vue中Mixin&extends的詳細使用方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

認識Mixin

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

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

官方定義Mixin

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

項目中如何使用Mixin

在src文件夾下創(chuàng)建一個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>
// 導(dǎo)入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的合并規(guī)則

如果Mixin對象中的選項和組件對象中的選項發(fā)生了沖突,那么Vue會如何操作呢?

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

<script>
// 導(dǎo)入
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屬性沖突,以組件的值優(yōu)先。組件中沒有的屬性,混入對象中的生效。

同名鉤子函數(shù)將會合并成一個數(shù)組,都會調(diào)用,混入函數(shù)先調(diào)用

值為對象的選項,如methods,computed等,將會合并為一個新對象,如果鍵名沖突,組件的值優(yōu)先

全局混入Mixin

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

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

官方定義extends

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

extends類似于mixin,相當(dāng)于繼承,但是只是繼承options Api中的內(nèi)容,不繼承template模板。

項目中使用extends

在components創(chuàng)建一個組件my.vue

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

在Home.vue文件下

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

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

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

總結(jié)

到此這篇關(guān)于Vue中Mixin&amp;extends詳細使用的文章就介紹到這了,更多相關(guān)Vue中Mixin&amp;extends使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解vue中$nextTick和$forceUpdate的用法

    詳解vue中$nextTick和$forceUpdate的用法

    這篇文章主要介紹了詳解vue中$nextTick和$forceUpdate的用法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • 詳解Vue.js iview實現(xiàn)樹形權(quán)限表(可擴展表)

    詳解Vue.js iview實現(xiàn)樹形權(quán)限表(可擴展表)

    這篇文章主要介紹了詳解Vue.js iview實現(xiàn)樹形權(quán)限表(可擴展表),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • Vue中watch使用方法詳解

    Vue中watch使用方法詳解

    watch就是當(dāng)值第一次綁定的時候,是不會執(zhí)行監(jiān)聽函數(shù)的,只有值誕生改變才會執(zhí)行。如果需要在第一次綁定的時候也執(zhí)行函數(shù),則需要用到immediate屬性,比如當(dāng)父組件向子組件動態(tài)傳值時,子組件props首次獲取到父組件傳來的No認知時,也需要執(zhí)行函數(shù)
    2023-01-01
  • Proxy中代理數(shù)據(jù)攔截的方法詳解

    Proxy中代理數(shù)據(jù)攔截的方法詳解

    這篇文章主要為大家詳細介紹了Proxy中代理數(shù)據(jù)攔截的方法,文中的示例代碼講解詳細,對我們學(xué)習(xí)或工作具有一定的借鑒價值,需要的可以參考一下
    2022-12-12
  • axios接口管理優(yōu)化操作詳解

    axios接口管理優(yōu)化操作詳解

    這篇文章主要為大家介紹了axios接口管理優(yōu)化操作詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • vue.js實現(xiàn)二級菜單效果

    vue.js實現(xiàn)二級菜單效果

    這篇文章主要為大家詳細介紹了vue.js實現(xiàn)二級菜單效果的具體方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • Vuex mutitons和actions初使用詳解

    Vuex mutitons和actions初使用詳解

    這篇文章主要介紹了Vuex mutitons和actions初使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 詳解Vue開發(fā)微信H5微信分享簽名失敗問題解決方案

    詳解Vue開發(fā)微信H5微信分享簽名失敗問題解決方案

    這篇文章主要介紹了詳解Vue開發(fā)微信H5微信分享簽名失敗問題解決方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • 在vue使用clipboard.js進行一鍵復(fù)制文本的實現(xiàn)示例

    在vue使用clipboard.js進行一鍵復(fù)制文本的實現(xiàn)示例

    這篇文章主要介紹了在vue使用clipboard.js進行一鍵復(fù)制文本的實現(xiàn)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • 詳解Vue.use自定義自己的全局組件

    詳解Vue.use自定義自己的全局組件

    本篇文章主要介紹了Vue.use自定義自己的全局組件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06

最新評論