Vue中mixin混入用法

  • 在src目录下创建一个mixins文件夹,文件夹下新建自己要定义的混入对象js文件

// minix.js
// 定义一个混入对象
export const mixin = {
  data() {
    return {
      num: 1
    }
  },
  created() {
    this.fun1()
    this.fun2()
    console.log('created mixin')
  },
  methods: {
    fun1() {
      console.log('fun1 mixin')
    },
    fun2() {
      console.log('fun2 mixin')
    },
  }
}
  • 在组件中使用

...
<script>
  import {mixin} from '@/mixins/mixin.js'
  export default {
    mixins: [mixin]
  }
</script>
特点
  1. 方法和参数在组件间不共享

例如:组件1和组件2中都引入了 minix.js

组件1 :对 num + 1 操作 --> 输出 num 的值为 2
组件2:                    输出 num 的值为 1
  1. 函数:例如created() 、mounted() 等,会进行合并调用,且同名函数先执行mixin中的同名函数

...
<script>
  import {mixin} from '@/mixins/mixin.js'
  export default {
    mixins: [mixin],
    created() {
      console.log('created component')
    }
  }
</script>
...

控制台输出结果:
created mixin
created component
  1. 对象:例如 methods,选项会被合并,键发生冲突时, 组件中的方法会覆盖mixin混入对象中的方法

...
<script>
  import {mixin} from '@/mixins/mixin.js'
  export default {
    mixins: [mixin],
    methods: {
      fun1() {
        console.log('fun1 component')
      },
      fun3() {
        console.log('fun3 component')
      },
    }
  }
</script>
...

控制台输出结果:
fun1 component
fun2 mixin
fun3 component
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值