Vue中Mixin&extends的詳細(xì)使用教程
認(rèn)識(shí)Mixin
目前我們使用組件化開發(fā)方式來開發(fā)應(yīng)用程序,但是在不同組件之間存在一些相同的代碼邏輯,此時(shí)我們希望對相同的代碼邏輯進(jìn)行抽取。
在vue2和vue3中都支持使用Mixin來解決,Mixin提供了一種非常靈活的方式,來分發(fā)Vue組件中的可復(fù)用功能,一個(gè)Mixin對象可以包含任何組件選項(xiàng),當(dāng)組件使用Mixin對象時(shí),所有Mixin對象的選項(xiàng)將被 混合 進(jìn)入該組件本身的選項(xiàng)中。
官方定義Mixin
Mixin 提供了一種非常靈活的方式,來分發(fā) Vue 組件中的可復(fù)用功能。一個(gè) mixin 對象可以包含任意組件選項(xiàng)。當(dāng)組件使用 mixin 對象時(shí),所有 mixin 對象的選項(xiàng)將被“混合”進(jìn)入該組件本身的選項(xiàng)。
項(xiàng)目中如何使用Mixin
在src文件夾下創(chuàng)建一個(gè)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">點(diǎn)擊按鈕</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計(jì)算屬性、foo方法,但是頁面中可以顯示。

Mixin的合并規(guī)則
如果Mixin對象中的選項(xiàng)和組件對象中的選項(xiàng)發(fā)生了沖突,那么Vue會(huì)如何操作呢?
<template>
<div class='home'>
{{msg}}<br>
{{message}}<br>
<button @click="foo">點(diǎn)擊按鈕</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ù)將會(huì)合并成一個(gè)數(shù)組,都會(huì)調(diào)用,混入函數(shù)先調(diào)用
值為對象的選項(xiàng),如methods,computed等,將會(huì)合并為一個(gè)新對象,如果鍵名沖突,組件的值優(yōu)先
全局混入Mixin
如果組件中的某些選項(xiàng),是所有的組件都需要擁有的,那么這個(gè)時(shí)候我們可以使用全局的mixin。一旦注冊,那么全局混入的選項(xiàng)將會(huì)影響每一個(gè)組件
const app = createApp(App)
app.mixin({
data() {
return {
msg:'global 中的data'
}
},
})
官方定義extends
允許一個(gè)組件擴(kuò)展到另一個(gè)組件,且繼承該組件選項(xiàng)。
extends類似于mixin,相當(dāng)于繼承,但是只是繼承options Api中的內(nèi)容,不繼承template模板。
項(xiàng)目中使用extends
在components創(chuàng)建一個(gè)組件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&extends詳細(xì)使用的文章就介紹到這了,更多相關(guān)Vue中Mixin&extends使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue如何實(shí)現(xiàn)變量表達(dá)式選擇器
這篇文章主要介紹了Vue如何實(shí)現(xiàn)變量表達(dá)式選擇器,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下2021-02-02
關(guān)于Vue?監(jiān)控?cái)?shù)組的問題
這篇文章主要介紹了Vue?監(jiān)控?cái)?shù)組的示例,主要包括Vue?是如何追蹤數(shù)據(jù)發(fā)生變化,Vue?如何更新數(shù)組以及為什么有些數(shù)組的數(shù)據(jù)變更不能被?Vue?監(jiān)測到,對vue監(jiān)控?cái)?shù)組知識(shí)是面試比較常見的問題,感興趣的朋友一起看看吧2022-05-05
vue項(xiàng)目中掃碼支付的實(shí)現(xiàn)示例(附demo)
本文主要介紹了vue項(xiàng)目中掃碼支付的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
前端vue實(shí)現(xiàn)的h5頁面接入微信支付流程(jsapi方式)
vue實(shí)現(xiàn)微信支付有三種方式,第一種方式是PC端支付,第二種方式是H5支付,第三種方式是微信公眾號(hào)支付,這篇文章主要給大家介紹了關(guān)于前端vue實(shí)現(xiàn)的h5頁面接入微信支付流程,文中介紹的方法是利用jsapi方式,通過代碼將實(shí)現(xiàn)的方法介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01
vue項(xiàng)目中created()被調(diào)用多次的踩坑實(shí)戰(zhàn)
在vue項(xiàng)目中我在created中調(diào)用了兩次get數(shù)據(jù)請求,所以下面這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目中created()被調(diào)用多次的踩坑實(shí)戰(zhàn),需要的朋友可以參考下2023-03-03

