Vue——mixin的使用

VUE官网给我们解释了

mixins 选项接受一个混入对象的数组。这些混入实例对象可以像正常的实例对象一样包含选项,他们将在 Vue.extend() 里最终选择使用相同的选项合并逻辑合并。举例:如果你的混入包含一个钩子而创建组件本身也有一个,两个函数将被调用。

Mixin 钩子按照传入顺序依次调用,并在调用组件自身的钩子之前被调用。
首先要了解的是什么是mixin(通俗)
——mixin是Vue给我们提供的混入的方法

一般适用的场景:

1.在项目中临时增加了一个需求(但是这个需求只存在一定的时间比如节假日促销)
2.项目中出现了大量的重复的方法(重复调用)

下面直接上代码(后面会有一些注意的事项)

在你的项目中创建一个文件夹mixin在index.js文件
我这里是Cache.js

export const Cache =  {
  data() {
    return {};
  },
  methods: {
    setCache() {
    },
    //取出缓存信息
    getCache() {
    }
  },
  created() {
    this.getCache();
  },
  destroyed() {
    this.setCache();
  }
};

然后在你的想要调用的组件书写

import  {Cache}  from "../../mixin/Cache";
export default {
  mixins:[Cache],
}

这个是我直接定义的一个const
还有一种是下面这种

export default {
  data() {
    return {};
  },
  methods: {
    setCache() {
      //判断缓存状态 做存取
     
    },
    //取出缓存信息
    getCache() {
     
    }
  },
  created() {
    this.getCache();
  },
  destroyed() {
    this.setCache();
  }
};

还是在你的页面调用

import  Cache  from "../../mixin/Cache";
export default {
  mixins:[Cache],
}

注意事项

在使用mixin时
mixin也是可以存在生命周期的,并且mixin的生命周期执行的顺序要大于组件本身的执行周期

例如:

1.mixin中有一个created 你组件也有一个created 这时会先执行mixin的created在执行组件的created
2.全局的mixin的生命周期执行的顺序会大于以上所说的所有

全局mixin执行 > mixin > 组件的生命周期钩子函数

mixin里面的方法名和组件里的方法名有冲突时 这个时候mixin的优先级小于组件的所以会触发组件的方法名
所以大家不要重名了哦

Vue 中,混合(mixins)是一种可以复用组件选项的方式。通过混合,我们可以将多个组件选项合并为一个组件选项,从而提高代码的复用性。 混合可以包含任意组件选项,如 data、methods、computed、watch、生命周期钩子等。当多个组件需要共享相同的选项时,我们可以使用混合来减少代码冗余。 使用混合非常简单,只需要定义一个混合对象,然后在组件中使用 mixins 选项将混合对象添加到组件选项中即可。例如: ``` // 定义一个混合对象 var myMixin = { created: function () { console.log('混合对象的 created 钩子被调用') } } // 使用混合对象 Vue.component('my-component', { mixins: [myMixin], created: function () { console.log('组件的 created 钩子被调用') } }) ``` 在上面的代码中,我们定义了一个混合对象 myMixin,其中包含了一个 created 生命周期钩子。然后在组件中使用 mixins 选项将 myMixin 添加到组件选项中。最终,组件的 created 钩子和混合对象的 created 钩子都会被调用。 需要注意的是,当混合对象和组件选项中含有同名选项时,混合对象的选项会覆盖组件选项的同名选项。如果混合对象中的选项是钩子函数,那么它们会在组件对应的钩子函数之前调用。 另外,混合对象可以被其他混合对象所继承,从而实现更复杂的代码复用。如果多个混合对象中含有同名选项,那么它们会按照混合对象的顺序依次调用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值