混合是一种灵活的分布式复用 Vue 组件的方式。混合对象可以包含任意组件选项。以组件使用混合对象时,所有混合对象的选项将被混入该组件本身的选项。当组件和混合对象含有同名选项时,这些选项将以恰当的方式混合。比如,同名钩子函数将混合为一个数组,因此都将被调用
var mixin ={
created:function() {
console.log('混合对象的钩子被调用')
}
}newVue({
mixins: [mixin],
created:function() {
console.log('组件钩子被调用')
}
})//-> "混合对象的钩子被调用"//-> "组件钩子被调用"
这里注意的是:
1:mixin定义的是一个对象;
2:mixin定义的对象中包含的内容,可以通过再vue中的mixins引入进去;
3:名字相同的会合并,根据这一原理,可以在不同的地方定义vue中的参数,然后合并;
4:注意的是这里并不是vue的子组件形式,子组件定义的数据,是可以直接在html中调用的,但是这里widget定义的对象,是通过mixin引入vue中的;
人才库中例子: