vue?父子組件共用mixins的注意點
父子組件共用mixins的注意點
- 父子組件正常引用(通過props傳值):父子組件之間的關系是相互獨立的
- 父子組件共用一個mixins:(在同一個作用域內,直接使用)
在開發(fā)過程中,會遇到tableData直接渲染的情況,數(shù)據(jù)量過大,則會拆分多個子組件,此時第一次進入頁面,調用api,后端傳參tableData,需要對數(shù)據(jù)進行組裝修改,我發(fā)現(xiàn)控制臺打印能出現(xiàn),頁面卻不渲染的情況,經驗證發(fā)現(xiàn)el-table中每次只能監(jiān)聽整個row的變化,row中某個屬性變化時,是無法追中的,要么this.$set(tableData,index,row)強行設置,index是row在tableData的索引,要么就正常組裝tableData,然后通過props傳給子組件,注意不能同名,否則子組件也引入mixins,這邊作用域會有沖突,其實出現(xiàn)這個問題還是對mixins的引入順序以及內部原理不太清晰。
mixins-beforeCreate——father-beforeCreate——mixins-created——father-created——mixins-beforeMount——father-beforeMount——son-beforeCreate——son-created——son-beforeMount——son-mounted——mixins-mounted——father-mounted
mixins中的import data components watch computed methods 等等都是對組件的拓展,相當于組件中沒有的話,mixins中有,組件中可以直接調用,當mixins中的定義的變量與組件中的同名發(fā)生沖突時,以組件中為準。
詳解mixins混入使用
當我們的項目越來越大,我們會發(fā)現(xiàn)組件之間可能存在很多相似的功能,你在一遍又一遍的復制粘貼相同的代碼段(data,method,watch、mounted等),如果我們在每個組件中去重復定義這些屬性和方法會使得項目出現(xiàn)代碼冗余并提高了維護難度,針對這種情況官方提供了Mixins特性
什么是Mixins?
mixins(混入),官方的描述是一種分發(fā) Vue 組件中可復用功能的非常靈活的方式,mixins是一個js對象,它可以包含我們組件中script項中的任意功能選項,如data、components、methods 、created、computed等等。
我們只要將共用的功能以對象的方式傳入 mixins選項中,當組件使用 mixins對象時所有mixins對象的選項都將被混入該組件本身的選項中來,這樣就可以提高代碼的重用性,使你的代碼保持干凈和易于維護。
什么時候使用Mixins?
當我們存在多個組件中的數(shù)據(jù)或者功能很相近時,我們就可以利用mixins將公共部分提取出來,通過 mixins封裝的函數(shù),組件調用他們是不會改變函數(shù)作用域外部的。
如何創(chuàng)建Mixins?
在src目錄下創(chuàng)建一個mixins文件夾,文件夾下新建一個myMixins.js文件。
前面我們說了mixins是一個js對象,所以應該以對象的形式來定義myMixins,在對象中我們可以和vue組件一樣來定義我們的data、components、methods 、created、computed等屬性,并通過export導出該對象

如何使用Mixins?
在需要調用的組件中引入myMixins.js文件,然后在export default 中引入你需要的對象即可

Mixins的特點
【5.1】方法和參數(shù)在各組件中不共享,雖然組件調用了mixins并將其屬性合并到自身組件中來了,但是其屬性只會被當前組件所識別并不會被共享,也就是其他組件無法從當前組件中獲取到mixins中的數(shù)據(jù)和方法。
①首先我們在混合對象myMixins.js中定義一個age字段和getAge方法
export const myMixins = {
components:{},
data() {
return {
age: 18,
}
},
mounted() {
this.getAge()
},
methods: {
getAge() {
console.log(this.age)
}
}② 組件1中對num進行+1操作
import { myMixins } from "@/mixins/myMixins.js";
export default {
mixins: [myMixins],
data() {
return {}
},
created() {
this.age++
},
}③組件2不進行操作
export default {
mixins: [myMixins],
data() {
return {}
},
}④我們分別切換到兩個頁面,查看控制臺輸出。會發(fā)現(xiàn)組件1改變了age里面的值,組件2中age值還是混合對象的初始值,并沒有隨著組件1的增加而改變

【5.2】引入mixins后組件會對其進行合并,將mixins中的數(shù)據(jù)和方法拓展到當前組件中來,在合并的過程中會出現(xiàn)沖突,接下來我們詳細了解Mixins合并沖突
Mixins合并沖突
【6.1】值為對象(components、methods 、computed、data)的選項,混入組件時選項會被合并,鍵沖突時優(yōu)先組件,組件中的鍵會覆蓋混入對象的
①我們在混入對象增加age屬性、getAge1方法和getAge2方法
// myMixins.js
export const myMixins = {
components:{},
data() {
return {
age: 18,
}
},
methods: {
getAge1() {
console.log("age1 from mixins =", this.age )
},
getAge2() {
console.log("age2 from mixins =", this.age )
},
}
}②我們在引入了myMixins文件的組件中,增加age屬性、getAge1方法和getAge3方法
// template.vue
import { myMixins } from "@/mixins/myMixins.js";
export default {
mixins: [myMixins],
data() {
return {
age: 20,
}
},
mounted() {
this.getAge1();
this.getAge2();
this.getAge3();
},
methods: {
getAge1() {
console.log('age1 from template =', this.age)
},
getAge3() {
console.log('age3 from template =', this.age)
},
}
}③我們會發(fā)現(xiàn),組件中的age覆蓋了混合對象的age,組件的getAge1方法覆蓋了混合對象的getAge1方法

【6.2】值為函數(shù)(created、mounted)的選項,混入組件時選項會被合并調用,混合對象里的鉤子函數(shù)在組件里的鉤子函數(shù)之前調用
// myMixins.js
export const myMixins = {
components:{},
data() {
return {}
},
created() {
console.log('xxx from mixins')
}
}
import { myMixins } from "@/mixins/myMixins.js";
export default {
mixins: [myMixins],
data() {
return {}
},
created() {
console.log('xxx from template')
}
}
與vuex的區(qū)別
vuex:用來做狀態(tài)管理的,里面定義的變量在每個組件中均可以使用和修改,在任一組件中修改此變量的值之后,其他組件中此變量的值也會隨之修改。Mixins:可以定義共用的變量,在每個組件中使用,引入組件中之后,各個變量是相互獨立的,值的修改在組件中不會相互影響。
與公共組件的區(qū)別
組件:在父組件中引入組件,相當于在父組件中給出一片獨立的空間供子組件使用,然后根據(jù)props來傳值,但本質上兩者是相對獨立的。Mixins:則是在引入組件之后與組件中的對象和方法進行合并,相當于擴展了父組件的對象與方法,可以理解為形成了一個新的組件。
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
vuex實現(xiàn)數(shù)據(jù)持久化的兩種方案
這兩天在做vue項目存儲個人信息的時候,遇到了頁面刷新后個人信息數(shù)據(jù)丟失的問題,在查閱資料后,我得出兩種解決數(shù)據(jù)丟失,使用數(shù)據(jù)持久化的方法,感興趣的小伙伴跟著小編一起來看看吧2023-08-08
使用vue初用antd 用v-model來雙向綁定Form表單問題
這篇文章主要介紹了使用vue初用antd 用v-model來雙向綁定Form表單問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
Vue動態(tài)控制input的disabled屬性的方法
這篇文章主要介紹了Vue動態(tài)控制input的disabled屬性的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-06-06
uniapp 小程序和app map地圖上顯示多個酷炫動態(tài)的標點效果(頭像后端傳過來)
這篇文章主要介紹了uniapp 小程序和app map地圖上顯示多個酷炫動態(tài)的標點效果(頭像后端傳過來),本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-09-09
詳解Vue自定義指令如何實現(xiàn)處理圖片加載失敗的碎圖
這篇文章主要介紹了詳解Vue自定義指令如何實現(xiàn)處理圖片加載失敗的碎圖,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧2023-02-02

