vue mixins混入
mixins文件
混入规则 :
1、 数据对象在内部会进行浅合并 (一层属性深度),在和组件的数据发生冲突时以组件数据优先。
2、 值为对象的选项,例如methods
,components
和directives
,将被混合为同一个对象。两个对象键名冲突时,取组件对象的键值对。
3、 同名钩子函数将混合为一个数组,因此都将被调用。另外,混入对象的钩子将在组件自身钩子之前调用。
所以即使你在引用的组件中 把created
重写 也是被合并(两个都会执行) 因为合并的策略不同 导致了methods
可以被重写 而created
ready
等只会被合并
1 const myMixin = { 2 data(){ 3 return{ 4 mixinsText:"这是数据对象", //在组件中可以被覆盖 5 } 6 }, 7 created() { 8 let option = this.$options.doNotInit; //可根据组件的在自定义选项判断是否需要执行hello函数 9 console.log(option); 10 if(option){ 11 this.hello() 12 } 13 14 }, 15 methods:{ 16 hello(){ 17 console.log('这是来自mixins的测试'); 18 } 19 } 20 }; 21 22 export default myMixin;
1 import HelloWorld from "@/components/HelloWorld.vue"; 2 import TodoList from "@/components/list.vue"; 3 import vModel from "@/components/v-model.vue"; 4 import Sync from "@/components/sync.vue"; 5 import mixin from '@/mixins' 6 export default { 7 mixins:[mixin], //局部注册 8 doNotInit:true, //自定义选项 9 data() { 10 return { 11 mixinsText:'这是对混入的数据对象的覆盖', 12 name: "这是父组件作用域", 13 listArray: [ 14 { id: 1, value: "this is ad1" }, 15 { id: 2, value: "this is ad2" } 16 ], 17 textValue: "要输入的值", 18 title:'这是测试sync的父组件的值' 19 }; 20 },
1 import Vue from 'vue' 2 import App from './App.vue' 3 import router from './router' 4 import store from './store' 5 6 import mixin from './mixins' 7 8 Vue.config.productionTip = false 9 10 new Vue({ 11 router, 12 store, 13 mixins:[mixin], //方法全局混入 14 render: h => h(App) 15 }).$mount('#app')