Vue.js之mixins混合組件詳解
混合以一種靈活的方式為組件提供分布復(fù)用功能?;旌蠈ο罂梢园我獾慕M件選項(xiàng)。當(dāng)組件使用了混合對象時(shí),混合對象的所有選項(xiàng)將被“混入”組件自己的選項(xiàng)中。
一、Mixins的基本用法
現(xiàn)在有個(gè)數(shù)字點(diǎn)擊遞增的程序,假設(shè)已經(jīng)完成了,這時(shí)我們希望每次數(shù)據(jù)變化時(shí)都能夠在控制臺(tái)打印出提示:“數(shù)據(jù)發(fā)生變化”.
代碼實(shí)現(xiàn)過程:
<div id="app">
<p>num:{{ num }}</p>
<P><button @click="add">增加數(shù)量</button></P>
</div>
<script>
var addLog = {
// 將updated鉤子混入到vue實(shí)例中
updated() {
console.log("數(shù)據(jù)放生變化,變化成" + this.num + ".");
}
}
var app = new Vue({
el: '#app',
data: {
num: 1
},
methods: {
add: function () {
this.num++;
}
},
mixins: [addLog], //混入
})
</script>

當(dāng)點(diǎn)擊按鈕時(shí)會(huì)觸發(fā)混入的 addLog 中的 updated 方法。
二、mixins的調(diào)用順序
- 從執(zhí)行的先后順序來說,都是
混入的先執(zhí)行,然后構(gòu)造器里的再執(zhí)行 data中的屬性 和methods里的方法,會(huì)覆蓋(構(gòu)造器覆蓋混入的屬性和方法)- 生命周期的鉤子則會(huì)調(diào)用2遍,不會(huì)覆蓋(
先調(diào)用混入鉤子再調(diào)用構(gòu)造器鉤子)
在上邊的代碼的構(gòu)造器里我們也加入了updated的鉤子函數(shù):
<div id="app">
<p>num:{{ num }}</p>
<P><button @click="add">增加數(shù)量</button></P>
</div>
<script>
var addLog = {
updated : function () {
console.log("數(shù)據(jù)放生變化,變化成" + this.num + ".");
}
}
var app = new Vue({
el: '#app',
data: {
num: 1
},
methods: {
add: function () {
this.num++;
}
},
updated: function () {
console.log("構(gòu)造器里的updated方法。")
},
mixins: [addLog], //混入
})
</script>

三、全局混入方式
全局混入的執(zhí)行順序要前于混入和構(gòu)造器里的方法。
<div id="app">
<p>num:{{ num }}</p>
<P><button @click="add">增加數(shù)量</button></P>
</div>
<script>
Vue.mixin({
updated: function () {
console.log('我是全局被混入的');
}
})
var addLog = {
updated : function () {
console.log("數(shù)據(jù)放生變化,變化成" + this.num + ".");
}
}
var app = new Vue({
el: '#app',
data: {
num: 1
},
methods: {
add: function () {
this.num++;
}
},
updated: function () {
console.log("構(gòu)造器里的updated方法。")
},
mixins: [addLog], //混入
})
</script>

順序總結(jié):全局混入 > 局部混入 > 構(gòu)造器
兩個(gè)對象鍵名沖突時(shí),取組件對象的鍵值對
當(dāng)混入和組件對象中都有test方法(重名)時(shí),最終的值取組件對象的鍵值對
<div id="app">
<p>num:{{ num }}</p>
<P>
<button @click="add">增加數(shù)量</button>
</P>
</div>
<script>
var addLog = {
updated: function () {
console.log("數(shù)據(jù)放生變化,變化成" + this.num + ".");
this.test();
},
methods: {
test: function () {
console.log('混入中的test')
}
}
}
var app = new Vue({
el: '#app',
data: {
num: 1
},
methods: {
add: function () {
this.num++;
},
test:function(){
console.log('組件對象中的test')
}
},
mixins: [addLog], //混入
})
</script>
到此這篇關(guān)于Vue.js之mixins混合組件詳解的文章就介紹到這了,更多相關(guān)Vue.js之mixins混合內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue實(shí)現(xiàn)移動(dòng)端輕量日期組件不依賴第三方庫的方法
這篇文章主要介紹了vue 移動(dòng)端輕量日期組件不依賴第三方庫,需要的朋友可以參考下2019-04-04
vue結(jié)合Axios+v-for列表循環(huán)實(shí)現(xiàn)網(wǎng)易健康頁面(實(shí)例代碼)
這篇文章主要介紹了vue結(jié)合Axios+v-for列表循環(huán)實(shí)現(xiàn)網(wǎng)易健康頁面,在項(xiàng)目下安裝axios,通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
vue3 element-plus el-tree自定義圖標(biāo)方式
這篇文章主要介紹了vue3 element-plus el-tree自定義圖標(biāo)方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
vue項(xiàng)目配置同一局域網(wǎng)可使用ip訪問的操作
這篇文章主要介紹了vue項(xiàng)目配置同一局域網(wǎng)可使用ip訪問的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10
vue中radio根據(jù)動(dòng)態(tài)值綁定checked無效的解決
這篇文章主要介紹了vue中radio根據(jù)動(dòng)態(tài)值綁定checked無效的解決,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
vue導(dǎo)航欄部分的動(dòng)態(tài)渲染實(shí)例
今天小編就為大家分享一篇vue導(dǎo)航欄部分的動(dòng)態(tài)渲染實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11

