vue mixin 与 自定义合并策略

本文介绍了Vue中的mixin如何应用于全局和局部,并探讨了在遇到属性冲突时的合并策略问题。默认情况下,局部定义会覆盖全局定义。如果需要更复杂的合并逻辑,可以自定义策略来决定组件中属性的选取。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

全局mixin

全局的mixin影响到所有页面及组件的内容.

Vue.mixin({
  data() {
    return {
      name: "tgc"
    }
  },
  created() {
    console.log('这是全局mixin')
  },
  methods: {
    foo() {
      console.log('这是一个全局方法')
    }
  },
})

局部mixin

内容定义跟全局一样,在使用的时候在需要的组件\页面引入注册即可.

import mixin from "./mixin/mixin";
export default {
    mixins: [mixin],
    data() {
        return {};
    },
    created() {
        console.log(this.name);
        this.foo();
    },
    components: {
    }
};

合并策略

假如原来页面有一个name, mixin里面也有一个name你需要的是哪一个或者还是他们合并的问题, 默认使用最后定义的值, 即简单地覆盖已有值.

Vue.config.optionMergeStrategies.name = function (toVal, fromVal) {
  if (!toVal) return fromVal
  if (!fromVal) return toVal
  return fromVal + toVal
}

上面的代码指的name是页面的, 而非data 里面的. 如果需要判断data里面的取舍再添加策略就行.
如果两个参数的选取策略相同, 可使用如下方法:

var strategies = Vue.config.optionMergeStrategies
strategies.myOption = strategies.methods
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值