Skip to content

mixin 与 mixins

mixin

mixin 用于全局混入,会影响到每个组件实例,通常插件都是这样做初始化的。

vue
<script>
Vue.mixin({
    beforeCreate(){
        console.log('init success')
    }
})
</script>
<script>
Vue.mixin({
    beforeCreate(){
        console.log('init success')
    }
})
</script>

mixins

多个组件中有相同的业务逻辑,就可以将这些逻辑剥离出来,通过 mixins 混入代码

vue
<script>
let myMixin = {
  created: function () {
    this.hello()
  },
  methods: {
    hello: function () {
      console.log('hello from mixin!')
    }
  },
  data(){
      return{
          msg:"hello world!"
      }
  }
}

// 定义一个使用混入对象的组件
var Component = Vue.extend({
  mixins: [myMixin],
  template:"<h1>{{msg}}</h1>"
})

new Component().$mount("#app")
</script>
<script>
let myMixin = {
  created: function () {
    this.hello()
  },
  methods: {
    hello: function () {
      console.log('hello from mixin!')
    }
  },
  data(){
      return{
          msg:"hello world!"
      }
  }
}

// 定义一个使用混入对象的组件
var Component = Vue.extend({
  mixins: [myMixin],
  template:"<h1>{{msg}}</h1>"
})

new Component().$mount("#app")
</script>

更新于: