mixins就是混入,将 根实例或是组件中的配置项 抽离出来, 单独管理
一个混入对象可以包含任意组件选项。
同一个生命周期,混入对象会比组件的先执行。
A:局部混入
var mixin = {
methods: {
sum(){
alert( 10*10 )
}
},
}
new Vue({
el: '#app',
data: {},
watch: {},
mixins: [mixin],
computed: {}
})
注意:
即使分离出去, 我们的配置项中也可以继续写分离出去的配置
如果说分离出去中的内容有冲突, 以组件中的配置项为准
B: 全局混入
注意: 全局混入慎用(不建议你使用)
理由:全局混入会影响所有的组件(实例)
Vue.mixin({
watch: {},
methods: {}
})
例如
<div id="app">
<button @click = "sum"> 点击 </button>
<button @click = "redecer"> 点击 </button>
<button @click = "changeName"> 点击 </button>
</div>
Vue.mixin({
methods: {
changeName(){
alert('zhangsan')
}
}
})
new Vue({
el: '#app',
data: {},
watch: {},
methods: {
redecer(){
alert( 100-10 )
},
sum(){
alert('张三')
}
},
computed: {}
})
下面整理一个完整的例子
1.创建一个test.js,用export暴露出mixins对象
export const mixinsTest = {
methods:{
hello(){
console.log("hello");
}
},
created(){
this.hello()
}
}
2.在组件中引入这个mixins对象,通过mixins:[xxx],使用mixins对象
<template>
<div>
home
</div>
</template>
<script>
import {mixinsTest} from '../util/test.js'
export default {
name: "Home",
data () {
return {
};
},
created(){
console.log("home");
},
//mixins的created会先被调用,然后再执行组件的created
mixins:[mixinsTest]
}
</script>
补充:
可以混入多个mixins对象
//暴露两个mixins对象
export const mixinsTest = {
methods: {
hello() {
console.log("hello mixins");
}
},
created() {
this.hello();
},
}
export const mixinsTest2 = {
methods:{
hello2(){
console.log("hello2");
}
},
created() {
this.hello2();
},
}
组件中引入两个mixins对象
<template>
<div>
home
</div>
</template>
<script>
import {mixinsTest,mixinsTest2} from '../util/test.js'
export default {
name: "Home",
data () {
return {
};
},
created(){
console.log("1212");
},
mixins:[mixinsTest2,mixinsTest] // 先调用那个mixins对象,就先执行哪个
}
</script>
<style lang="css" scoped>
</style>
打印的顺序是:
hello2
hello2 mixins
1212