Vue mixins混入使用解析
前言
當(dāng)我們的項(xiàng)目越來(lái)越大,我們會(huì)發(fā)現(xiàn)組件之間可能存在很多相似的功能,你在一遍又一遍的復(fù)制粘貼相同的代碼段(data,method,watch、mounted等),如果我們?cè)诿總€(gè)組件中去重復(fù)定義這些屬性和方法會(huì)使得項(xiàng)目出現(xiàn)代碼冗余并提高了維護(hù)難度,針對(duì)這種情況官方提供了Mixins特性
一、什么是Mixins
mixins(混入),官方的描述是一種分發(fā) Vue 組件中可復(fù)用功能的非常靈活的方式,mixins是一個(gè)js對(duì)象,它可以包含我們組件中script項(xiàng)中的任意功能選項(xiàng),如data、components、methods 、created、computed等等。我們只要將共用的功能以對(duì)象的方式傳入 mixins選項(xiàng)中,當(dāng)組件使用 mixins對(duì)象時(shí)所有mixins對(duì)象的選項(xiàng)都將被混入該組件本身的選項(xiàng)中來(lái),這樣就可以提高代碼的重用性,使你的代碼保持干凈和易于維護(hù)。
二、什么時(shí)候使用Mixins
當(dāng)我們存在多個(gè)組件中的數(shù)據(jù)或者功能很相近時(shí),我們就可以利用mixins將公共部分提取出來(lái),通過 mixins封裝的函數(shù),組件調(diào)用他們是不會(huì)改變函數(shù)作用域外部的。
三、如何創(chuàng)建Mixins
在src目錄下創(chuàng)建一個(gè)mixins文件夾,文件夾下新建一個(gè)myMixins.js文件。前面我們說(shuō)了mixins是一個(gè)js對(duì)象,所以應(yīng)該以對(duì)象的形式來(lái)定義myMixins,在對(duì)象中我們可以和vue組件一樣來(lái)定義我們的data、components、methods 、created、computed等屬性,并通過export導(dǎo)出該對(duì)象
四、如何使用Mixins
在需要調(diào)用的組件中引入myMixins.js文件,然后在export default 中引入你需要的對(duì)象即可
五、Mixins的特點(diǎn)
【5.1】方法和參數(shù)在各組件中不共享,雖然組件調(diào)用了mixins并將其屬性合并到自身組件中來(lái)了,但是其屬性只會(huì)被當(dāng)前組件所識(shí)別并不會(huì)被共享,也就是其他組件無(wú)法從當(dāng)前組件中獲取到mixins中的數(shù)據(jù)和方法。
①首先我們?cè)诨旌蠈?duì)象myMixins.js中定義一個(gè)age字段和getAge方法
export const myMixins = { components:{}, data() { return { age: 18, } }, mounted() { this.getAge() }, methods: { getAge() { console.log(this.age) } } }
② 組件1中對(duì)num進(jìn)行+1操作
import { myMixins } from "@/mixins/myMixins.js"; export default { mixins: [myMixins], data() { return {} }, created() { this.age++ }, }
③組件2不進(jìn)行操作
export default { mixins: [myMixins], data() { return {} }, }
④我們分別切換到兩個(gè)頁(yè)面,查看控制臺(tái)輸出。會(huì)發(fā)現(xiàn)組件1改變了age里面的值,組件2中age值還是混合對(duì)象的初始值,并沒有隨著組件1的增加而改變
【5.2】引入mixins后組件會(huì)對(duì)其進(jìn)行合并,將mixins中的數(shù)據(jù)和方法拓展到當(dāng)前組件中來(lái),在合并的過程中會(huì)出現(xiàn)沖突,接下來(lái)我們?cè)敿?xì)了解Mixins合并沖突
六、Mixins合并沖突
【6.1】值為對(duì)象(components、methods 、computed、data)的選項(xiàng),混入組件時(shí)選項(xiàng)會(huì)被合并,鍵沖突時(shí)優(yōu)先組件,組件中的鍵會(huì)覆蓋混入對(duì)象的
①我們?cè)诨烊雽?duì)象增加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 ) }, } }
②我們?cè)谝肓薽yMixins文件的組件中,增加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) }, } }
③我們會(huì)發(fā)現(xiàn),組件中的age覆蓋了混合對(duì)象的age,組件的getAge1方法覆蓋了混合對(duì)象的getAge1方法
【6.2】值為函數(shù)(created、mounted)的選項(xiàng),混入組件時(shí)選項(xiàng)會(huì)被合并調(diào)用,混合對(duì)象里的鉤子函數(shù)在組件里的鉤子函數(shù)之前調(diào)用
// 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:用來(lái)做狀態(tài)管理的,里面定義的變量在每個(gè)組件中均可以使用和修改,在任一組件中修改此變量的值之后,其他組件中此變量的值也會(huì)隨之修改。
Mixins:可以定義共用的變量,在每個(gè)組件中使用,引入組件中之后,各個(gè)變量是相互獨(dú)立的,值的修改在組件中不會(huì)相互影響。
八、與公共組件的區(qū)別
組件:在父組件中引入組件,相當(dāng)于在父組件中給出一片獨(dú)立的空間供子組件使用,然后根據(jù)props來(lái)傳值,但本質(zhì)上兩者是相對(duì)獨(dú)立的。
Mixins:則是在引入組件之后與組件中的對(duì)象和方法進(jìn)行合并,相當(dāng)于擴(kuò)展了父組件的對(duì)象與方法,可以理解為形成了一個(gè)新的組件。
到此這篇關(guān)于Vue mixins混入使用解析的文章就介紹到這了,更多相關(guān)Vue mixins混入內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue3動(dòng)態(tài)路由(響應(yīng)式帶參數(shù)的路由)變更頁(yè)面不刷新的問題解決辦法
問題來(lái)源是因?yàn)槲业拈_源項(xiàng)目Maple-Boot項(xiàng)目的網(wǎng)站前端,因?yàn)轫?xiàng)目主打的內(nèi)容發(fā)布展示,所以其中的內(nèi)容列表頁(yè)會(huì)根據(jù)不同的菜單進(jìn)行渲染不同的路由,本文降介紹Vue3動(dòng)態(tài)路由變更頁(yè)面不刷新的問題解決辦法,需要的朋友可以參考下2024-07-07vue如何點(diǎn)擊多個(gè)tab標(biāo)簽打開關(guān)閉多個(gè)頁(yè)面
這篇文章主要介紹了vue如何點(diǎn)擊多個(gè)tab標(biāo)簽打開關(guān)閉多個(gè)頁(yè)面,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09VUE3?Vite打包后動(dòng)態(tài)圖片資源不顯示問題解決方法
這篇文章主要給大家介紹了關(guān)于VUE3?Vite打包后動(dòng)態(tài)圖片資源不顯示問題的解決方法,可能是因?yàn)樵诓渴鸷蟮姆?wù)器環(huán)境中對(duì)中文文件名的支持不完善,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-09-09vue-cli項(xiàng)目?jī)?yōu)化方法- 縮短首屏加載時(shí)間
這篇文章主要介紹了vue-cli項(xiàng)目?jī)?yōu)化 縮短首屏加載時(shí)間,需要的朋友可以參考下2018-04-04VUE+Canvas 實(shí)現(xiàn)桌面彈球消磚塊小游戲的示例代碼
這篇文章主要介紹了VUE+Canvas 實(shí)現(xiàn)桌面彈球消磚塊小游戲,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04Vue在頁(yè)面數(shù)據(jù)渲染完成之后的調(diào)用方法
今天小編就為大家分享一篇Vue在頁(yè)面數(shù)據(jù)渲染完成之后的調(diào)用方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2018-09-09vue項(xiàng)目中路由跳轉(zhuǎn)頁(yè)面不變問題及解決
這篇文章主要介紹了vue項(xiàng)目中路由跳轉(zhuǎn)頁(yè)面不變問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08vue如何實(shí)現(xiàn)動(dòng)態(tài)的選中狀態(tài)切換效果
這篇文章主要介紹了vue如何實(shí)現(xiàn)動(dòng)態(tài)的選中狀態(tài)切換效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04