vue2中的mixins

2017-12-22  本文已影响0人  胖太_91bf

mixins: 混合对象, 功能类似于Vue.extend();

使用时,在组件的选项中添加mixins: [mixin]

var mixin = {
  methods: {
    foo: function () {
      console.log('foo')
    },
    conflicting: function () {
      console.log('from mixin')
    }
  }
}

var vm = new Vue({
  mixins: [mixin],
  methods: {
    bar: function () {
      console.log('bar')
    },
    conflicting: function () {
      console.log('from self')
    }
  }
})

vm.foo() // => "foo"
vm.bar() // => "bar"
vm.conflicting() // => "from self"

注意事项:

1-minxins可以包含任意组件对象的选项(例如:methods, mounted等钩子函数, components, directives等等),
2-当组件使用minxins对象时, minxins对象的选项, 将被混合进组件的选项
3-如果minxins对象的选项是钩子函数(created, mounted等)怎会先于组件的钩子函数执行
4-如果minxins对象的选项为对象(如methods, directives,components), 则会合并为同意对象, 如果键值发生冲突, 则会使用组件的键值对

上一篇 下一篇

猜你喜欢

热点阅读