vue中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),通過(guò) 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等屬性,并通過(guò)export導(dǎo)出該對(duì)象
myMixins.js:
四、如何在組件中使用Mixins?
在需要調(diào)用的組件中引入myMixins.js文件,然后在export default 中引入你需要的對(duì)象即可
五、Mixins的特點(diǎn)
(1)方法和參數(shù)在各組件中不共享,雖然組件調(diào)用了mixins并將其屬性合并到自身組件中來(lái)了,但是其屬性只會(huì)被當(dāng)前組件所識(shí)別并不會(huì)被共享,也就是其他組件無(wú)法從當(dāng)前組件中獲取到mixins中的數(shù)據(jù)和方法。
① todo.vue:組件1中對(duì)num進(jìn)行+1操作
// todo.vue // 引入 myMixins.js 文件 import {myMixins} from './myMixins';export default {mixins: [myMixins],data() {return {}},created() {this.num++},}② list.vue 組件2不進(jìn)行操作
// list.vue import {myMixins} from './myMixins';export default {mixins: [myMixins],data() {return {}}, }③ 分別切換到兩個(gè)頁(yè)面,查看控制臺(tái)輸出
會(huì)發(fā)現(xiàn)組件1改變了num里面的值,組件2中num值還是混合對(duì)象的初始值,并沒(méi)有隨著組件1的增加而改變
(2)引入mixins后組件會(huì)對(duì)其進(jìn)行合并,將mixins中的數(shù)據(jù)和方法拓展到當(dāng)前組件中來(lái),在合并的過(guò)程中會(huì)出現(xiàn)沖突,接下來(lái)我們?cè)敿?xì)了解Mixins合并沖突
六、關(guān)于Mixins合并沖突
(1)值為對(duì)象(components、methods 、computed、data)的選項(xiàng),混入組件時(shí)選項(xiàng)會(huì)被合并,鍵沖突時(shí)優(yōu)先組件,組件中的鍵會(huì)覆蓋混入對(duì)象的
① 我們?cè)诨烊雽?duì)象增加num屬性、getDate1方法和getDate2方法
// myMixins.js export const myMixins = {components:{},data() {return {num: 1,}},methods: {getDate1() {console.log("num1 from mixins =", this.num )},getDate2() {console.log("num2 from mixins =", this.num )},} }② 我們?cè)谝肓薽yMixins文件的 todo.vue 組件中,增加num屬性、getDate1方法和getDate3方法
// todo.vue import { myMixins } from "./myMixins.js"; export default {mixins: [myMixins],data() {return {num: 18,}},mounted() {this.getDate1();this.getDate2();this.getDate3();},methods: {getDate1() {console.log('num1 from template =', this.num)},getDate3() {console.log('num3 from template =', this.num)},} }③ 我們會(huì)發(fā)現(xiàn),組件中的age覆蓋了混合對(duì)象的age,todo.vue 組件的getDate1方法覆蓋了混合對(duì)象的getDate1方法
(2)值為函數(shù)(created、mounted)的選項(xiàng),混入組件時(shí)選項(xiàng)會(huì)被合并調(diào)用,混合對(duì)象里的鉤子函數(shù)在組件里的鉤子函數(shù)之前調(diào)用
myMixins.js 中的console:
// myMixins.js export const myMixins = {components:{},data() {return {}},created() {console.log('hello from mixin')}todo.vue 中的 console
// todo.vue import { myMixins } from "./myMixins.js";export default {mixins: [myMixins],data() {return {}},created() {console.log('hello from self')} }控制臺(tái)打印
七、vue中mixins的使用方法和注意點(diǎn) (異步請(qǐng)求的情況)
當(dāng)混合里面包含異步請(qǐng)求函數(shù),而我們又需要在組件中使用異步請(qǐng)求函數(shù)的返回值時(shí),我們會(huì)取不到此返回值,如下:
Mymixins.js文件中
// myMixins.js export const myMixins = {components:{},data() {return {num: 1,}},methods: {getDate1() {new Promise((resolve,reject) => {let a = 1;setTimeout(() => {resolve(a)},500)}).then(res => {console.log(res,'res');return res})},} }todo.vue 文件中
// todo.vue import { myMixins } from "./myMixins.js";export default {mixins: [myMixins],data() {return {}},mounted() {console.log(this.getDate1,'template1-func_one')} }
解決方案:不要返回結(jié)果而是直接返回異步函數(shù)
Mymixins.js文件中
// myMixins.js export const myMixins = {components:{},data() {return {num: 1,}},methods: {async getDate1() {let result = await new Promise((resolve,reject) => {let a = 1;setTimeout(() => {resolve(1)},500)})return result},} }todo.vue 文件中
// todo.vue import { myMixins } from "./myMixins.js";export default {mixins: [myMixins],data() {return {}},mounted() {this.getDate1().then(res => {console.log(res,'template1-res')})} }總結(jié)
以上是生活随笔為你收集整理的vue中mixins的使用方法和注意地方的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 楼兰古国之谜(千年古国楼兰消失之谜)
- 下一篇: vue生命周期(列表详解)