Vue 混入(mixin)详细介绍(可复用性、全局混入)

基础

混入(mixin)提供了一种非常灵活的方式,来分发 Vue 组件中的可复用功能。一个混入对象可以包含任意组件选项(如data、methods、mounted等等)。当组件使用混入对象时,所有混入对象的选项将被“混合”进入该组件本身的选项。 

基本使用

1、定义一个混入(mixin)

let mixin = {
  created() {
    console.log("我是mixin里面的created!")
  },
  methods: {
    hello() {
      console.log("hello from mixin!")
    }
  }
}

export default mixin

2、在组件(Home.vue)中使用

<template>
  <div class="home">
    <span>This is a Home page</span>
  </div>
</template>

<script>
import myMixins from "../mixins";   //导入混入(mixin)
export default {
  name: 'Home',
  mixins: [myMixins]     //使用混入(mixin)
}
</script>

注意观察Home组件里面,并没有任何的生命周期钩子或者方法,但是打开页面之后查看控制台,却打印了内容,这就是混入对象中的created钩子中的console.log()。

现在,在Home组件加上mounted生命周期钩子

<template>
  <div class="home">
    <span>This is a Home page</span>
  </div>
</template>

<script>
import myMixins from "../mixins";
export default {
  name: 'Home',
  mixins: [myMixins],
  mounted(){         
    this.hello()     //在该组件中并没用定义hello方法,使用的是混入中的hello
  }
}
</script>

刷新页面,查看控制台打印信息

非但没报错, 还打印出了混入对象中定义的hello方法,即执行了混入对象中的mounted生命周期钩子,也验证了当前组件中合并了混入对象中定义的选项和方法。这就是混入的基本使用。

选项合并

当组件和混入对象含有同名选项时,这些选项将以恰当的方式进行“合并”。数据对象在内部会进行递归合并,并在发生冲突时以组件数据优先。

如下,我们在Home.vue中定义与混入对象中同名的选项

mixin.js

Home.vue 

刷新页面,查看控制台打印信息

此时,同名的created生命周期钩子进行了合并,合并为一个数组,因此都将被调用。另外,混入对象的钩子将在组件自身钩子之前调用。而methods中的hello方法因为冲突,在合并时保留组件中的hello,即优先当前组件的选项,因此打印的是“hello from Home!”。

值为对象的选项,例如 methodscomponents 和 directives,将被合并为同一个对象。两个对象键名冲突时,取组件对象的键值对。

可复用性

开篇提过,混入对象可成为一个可复用功能,我们在另外的组件中引入已定义的混入对象,可实现同样的逻辑与功能。

如在另外一个组件About.vue使用该混入对象

<template>
  <div class="about">
    <span>This is an About page</span>
  </div>
</template>

<script>
import myMixins from "../mixins";
export default {
  name: "About",
  mixins: [myMixins]
};
</script>

刷新页面,进行切换,查看控制台打印信息

混入对象中的console.log均被执行了,实现了逻辑或功能的复用。

那么有个问题,如果很多个组件同时使用同一个混入对象,这时候都要重复一个步骤,就是先导入混入对象,然后再使用,类似如下

<script>
import myMixins from "../mixins";
export default {
  mixins: [myMixins]
};
</script>

这样未免有点繁琐,且代码冗余,此时我们可以使用全局混入来优化这个问题。

全局混入

混入也可以进行全局注册。使用时格外小心!一旦使用全局混入,它将影响每一个之后创建的 Vue 实例。使用恰当时,这可以用来为自定义选项注入处理逻辑。

在main.js中通过Vue.mixin()引入混入对象即可全局使用(作用于该Vue实例下的所有组件)

import mixin from './mixins';
Vue.mixin(mixin)

此时我们将Home.vue、About.vue中使用混入对象的代码注释

刷新页面,进行切换,查看控制台打印信息

效果与在每个组件中单独引入混入对象相同,这便是全局混入。

请谨慎使用全局混入,因为它会影响每个单独创建的 Vue 实例 (包括第三方组件)。大多数情况下,只应当应用于自定义选项,就像上面示例一样。推荐将其作为插件发布,以避免重复应用混入。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码
< <上一篇

)">
下一篇>>