vue之混入(mixin)的详解

一、前言:

混入的作用:可以省很多代码(高类聚低耦合),还方便维护;
个人理解:混入就是在一个公共的实例中写入公共的数据或者方法,这样的话vue会自动注入到(全局混入会注入到每一个实例组件中)、(单页面引入的会注入到引入的组件中)。混入的对象也就是mixin中可以写入的内容包含任意组件选项- - - - - -(也就是说你在export default { } 里边的内容都是可以混入的)有一种类似公共方法的感觉,但是可以写公共的data里面的数据,这一点比较方便。

二、混入的方式一:单页面引入混入

首先创建一个 mixin 文件夹,然后再在里面创建一个mixin.js文件
然后再创建混入对象:

let mixin = {
    data(){
        return{
            str:'你好'
        }
    },
    created() {
        console.log("我是混入的生命周期函数")
    },
    methods: {
        showToast(){
            alert("我是混入中的方法啊!")
        }
    },
}

// 记住,最后一定要导出
export default mixin 

在组件中使用混入:

import mixin from '../mixin/mixin.js'	// 首先引入这个混入对象
export default {
    mixins:[mixin],		// 然后注册你引入的这个混入对象
}
混入方式二、全局混入:

创建混入对象的方式还是和上面方法一样,我这里就直接引入了;

在main.js中引入混入对象并全局注册

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

这里需要注意的是,在全局注册混入对象的时候是Vue.mixin(mixin);不是Vue.use(mixin);
这样第一种方法,就全局注入到每一个spa实例中了。
科普一下:spa应用就是单页面应用、像我们平时所做的vue项目都是spa应用;

注意事项:

1、而对于混入对象以及组件自身的created钩子函数呢,它们都将被调用。但混入对象的钩子会在组件自身的钩子之前调用。
2、如果组件自身定义了与钩子对象中同名的数据或方法,为了避免冲突,vue将优先使用组件自身的数据或方法 (也就是重名了就只会调用组件内部的数据或方法)。

你可能感兴趣的:(vue,vue.js)