混入 (mixin) 提供了一种很是灵活的方式,来分发 Vue 组件中的可复用功能。一个混入对象能够包含任意组件选项。当组件使用混入对象时,全部混入对象的选项将被“混合”进入该组件自己的选项。vue
这句话咱们能够理解为在js代码中定义一个混入对象,里面能够包含一个组件能够有的任何组件选项:data、method、watch、钩子函数等,使用的话,分为局部混入和全局混入。markdown
首先新建一个mixin.js文件,添加如下代码。app
// 混入 export default { data() { return { msg: "Hello Word!" }; }, created() {}, computed: {}, methods: { show() { console.log(this.msg); } } };
这个文件格式应该比较眼熟,一个.vue文件包含template、script、style三个部分,mixin.js这个文件很像script这个部分。对的,script里的data、method、watch、钩子函数等,均可以定义到mixin.js这个文件。那这里面可能就会存在问题,好比mixin.js中的data、method等和引用混入的组件中存在冲突,这时采用组件内部优先。ide
局部混入函数
<template> <div id="myVue"> <span @click="show">{{msg}}</span> </div> </template> <script> import myMixin from "./mixin.js"; export default { name: "myVue", mixins: [myMixin], created() { console.log("组件自身的钩子函数"); }, }; </script>
首先咱们引入mixin.js,而后就能够调用混入的方法和数据this
全局混入spa
在main.js中引入该文件并使用mixin方法进行注册code
import Vue from 'vue'; import App from './App'; // 增长混入 import myMixin from "@/mixin"; Vue.mixin(myMixin); new Vue({ el: '#app', components: { App }, template: '<App/>' });
全局注册后,在任意组件均可以使用,谨慎使用全局混入对象,由于会影响到每一个单首创建的 Vue 实例 (包括第三方模板)。component