Mixin是面向对象程序设计语言中的类,提供了方法的实现。其他类可以访问mixin类的方法而不必成为其子类
Mixin类通常作为功能模块,在需要该功能时“混入”,有利于代码复用又避免了多继承的复杂
vue中的mixin
mixin(混入),提供了一种非常灵活的方式,来分发 Vue 组件中的可复用功能
本质其实就是一个js对象,它可以包含我们组件中任意功能选项,如data、components、methods、created、computed等等。
共用的功能以对象的方式传入 mixins选项中,当组件使用 mixins对象时所有mixins对象的选项都将被混入该组件本身的选项中。
var myMixin = {
created: function () {
this.hello()
},
methods: {
hello: function () {
console.log('hello from mixin!')
}
}
}
Vue.component('componentA',{
mixins: [myMixin]
})
组件通过mixins属性调用mixin对象( 该组件在使用的时候,混合了mixin里面的方法,在自动执行created生命钩子,执行hello方法 )
Vue.mixin({
created: function () {
console.log("全局混入")
}
})
通过Vue.mixin()
进行全局的混入
Vue.mixin:/src/core/global-api/mixin.js
主要是调用merOptions方法
options:/src/core/util/options.js
合并策略: