Vue Mixin 与小程序 Mixins 应用

一.什么是Mixin(混入)

混入 (mixins):是一种分发 Vue 组件中可复用功能的非常灵活的方式。混入对象可以包含任意组件选项。当组件使用混入对象时,所有混入对象的选项将被混入该组件本身的选项。

二.为什么要使用混入

1.1 Mixin的优点

混入可以减少程序中重复的功能,增强函数的复用性.当一个应用程序可能需要在各种对象中共享行为时,我们可以通过Mixin中维持这种共享功能并专注于程序中真正不同的功能,轻松避免任何重复,使项目结构更加清晰更加易于维护。

2.1 Mixin的缺点

Mixin是一种很灵活的代码复用方式,但把功能属性和方法导入,如果文件过多,会导致属性方法来源方面的不确定性,在大型系统中需要对项目文件的划分以及整体的掌控。

三.Mixins的特点

  1. 方法和参数在各组件中不共享
  2. 数据对象
    mixin的数据对象和组件的数据发生冲突时以组件数据优先。
  3. 值为对象的选项
    如methods,components等,选项会被合并,键冲突的组件会覆盖混入对象的,比如混入对象里有个方法A,组件里也有方法A,这时候在组件里调用的话,执行的是组件里的A方法

四.Vue Mixins 应用

  • 定义公共的mixins文件:如mixin.vue

<template>

</template>

<script>
    export default {
        name: 'mixins-test-main',
        components: {},
        props: {},
        data () {
            return {
                mixinData: 'mixin中的变量'
            }
        },
        methods: {
            mixinFunction () {
                return '我是mixins里面的公共方法'
            },
        },
        mounted () {
        },
        computed: {}
    }
</script>

<style scoped>
</style>
  • 在你页面内调用:需要import这个mixins文件 ,然后通过mixins:[‘文件名’]来使用
<template>
    <div>
        <div @click="handleMixin">调用mixin方法</div>
    </div>
</template>

<script>
    import MixinItem from './mixin'

    export default {
        name: 'mixin-test-comp',
        props: {},
        mixins: [MixinItem],
        components: {},
        data () {
            return {}
        },
        methods: {
            handleMixin () {
                console.log('mixin-data=========', this.mixinData)
                let mixfun = this.mixinFunction()
                console.log('mixin-fun====>>>', mixfun)
            },
        },
        mounted () {
        },
        computed: {}
    }
</script>

<style scoped>
</style>

注意点:混入的方法会覆盖掉之前页面内部的同名属性或方法。

五.小程序Mixins应用

小程序的Page并没有给出混入的API以及解方案,如果想要实现混入,需要自己封装Mixins方法,来实现对象方法以及属性的混入,达到代码的复用的目的。

1.1 Mixins 使用

  1. 在项目根目录中新建 mixins 文件夹,并在 mixins 文件夹之下新建 tabbar-badge.js 文件,封装为一个 mixin 文件:
module.exports = {
    data:{
        two:"我是Mixin里面的数据"
    },
    b(){
        console.log("我是b函数",this.data.one)
    }
}
  1. 导入 @/mixins/tabbar-badge.js 模块并进行使用
import mixin1 from "../../mixins/public/mixin1.js";
Page({
    mixins:[mixin1],
    data:{
        one:"我是index里面的数据"
    },
    a(){
        console.log("我是a函数",this.data.two)
    },
    onLoad(){
        this.a();
        this.b();
    }
})

六.如果发生命名冲突该怎么办?

当mixin中的数据、方法或任何组件选项与组件中的选项具有相同的名称时,可能会发生组件与其mixin之间的命名冲突。如果发生这种情况,则组件本身的属性将优先。
示例代码如下:

// mixin.js 
export default {
   data () {
      title: ‘Mixin’
   }
}

// main.js file
import mixin from./mixin.js’
export default {
   mixins: [mixin],
   data () {
      title: ‘Component’
   },
   created: function () {
      console.log(this.title)   // "Component"
   }
}

七.与vuex的区别

  1. vuex:用来做状态管理的,里面定义的变量在每个组件中均可以使用和修改,在任一组件中修改此变量的值之后,其他组件中此变量的值也会随之修改。
  2. Mixins:可以定义共用的变量,在每个组件中使用,引入组件中之后,各个变量是相互独立的,值的修改在组件中不会相互影响。

八.与公共组件的区别

  1. 组件:在父组件中引入组件,相当于在父组件中给出一片独立的空间供子组件使用,然后根据props来传值,但本质上两者是相对独立的。

  2. Mixins:则是在引入组件之后与组件中的对象和方法进行合并,相当于扩展了父组件的对象与方法,可以理解为形成了一个新的组件。

总结:对于Vue 的 mixin,我们还有很多要了解,但是上面这些知识在开发中一般足够用了,混合对于封装一小段想要复用的代码来讲是有用的,混合不需要传递状态,但是这种模式当然也可能会被滥用。所以我们还是需要仔细斟酌使用。

### Vue2 中 `mixin` 和 `mixins` 的区别及用法 #### 一、基本概念 在 Vue2 中,`mixin` 是一种用于实现代码复用的功能机制。它可以将一些通用的方法、数据、生命周期钩子等封装成一个对象,在多个组件之间共享。而 `mixins` 则是用来声明需要引入的一个或多个 `mixin` 对象的选项。 - **`mixin`**: 单个混入对象,通常是一个包含组件选项的对象[^1]。 - **`mixins`**: 多个混入对象组成的数组,允许在一个组件中同时引入多个 `mixin` 实现更复杂的复用需求[^1]。 --- #### 二、具体用法 ##### 1. 定义和使用单个 `mixin` 定义一个简单的 `mixin` 对象: ```javascript // 定义一个 mixin 对象 const myMixin = { data() { return { sharedData: 'This is from a single mixin' }; }, methods: { sharedMethod() { console.log('Shared method called'); } }, created() { console.log('Created hook from single mixin'); } }; ``` 在组件中使用该 `mixin`: ```javascript export default { mixins: [myMixin], // 使用单个 mixin mounted() { this.sharedMethod(); // 可以访问来自 mixin 的方法 console.log(this.sharedData); // 访问来自 mixin 的数据 } }; ``` --- ##### 2. 同时使用多个 `mixin` 如果需要在同一组件中引入多个 `mixin`,可以通过 `mixins` 数组的形式完成: ```javascript // 定义两个不同的 mixin 对象 const firstMixin = { data() { return { name: 'First' }; }, methods: { greet() { console.log(`Hello, I'm ${this.name}`); } } }; const secondMixin = { data() { return { age: 20 }; }, methods: { info() { console.log(`${this.name} is ${this.age} years old`); } } }; // 在组件中同时引入这两个 mixin export default { mixins: [firstMixin, secondMixin], mounted() { this.greet(); // 输出 "Hello, I'm First" this.info(); // 输出 "First is 20 years old" } }; ``` --- #### 三、`mixin` 和 `mixins` 的主要区别 | 特性 | `mixin` | `mixins` | |-------------------|----------------------------------------|---------------------------------------| | 类型 | 单个混入对象 | 多个混入对象组成的数组 | | 使用场景 | 当只需要引入单一功能模块时 | 需要组合多个功能模块时 | | 数据/方法冲突处理 | 如果存在同名的数据或方法,后者会覆盖前者[^4] | 同样遵循覆盖原则,但顺序会影响最终的结果[^4] | --- #### 四、注意事项 1. **命名冲突问题** - 当多个 `mixin` 或者组件本身具有相同的属性或方法名称时,Vue 会按照一定的优先级规则进行合并。一般而言,组件内的定义会覆盖 `mixin` 中的定义[^3]。 2. **复杂度管理** - 过度依赖 `mixin` 可能会使代码变得难以维护,尤其是在大型项目中。推荐仅在必要的情况下使用,并保持其职责单一化[^2]。 3. **性能影响** - 每次引入 `mixin` 都会在组件初始化阶段增加额外的合并开销,因此应权衡利弊后再决定是否使用[^4]。 --- ### 总结 `mixin` 提供了一种灵活的方式来实现跨组件的代码复用,适用于小型工具函数或者简单逻辑抽取;而 `mixins` 则进一步增强了这一能力,支持一次性引入多个 `mixin`,从而满足更加复杂的开发需求。但在实际工作中需要注意合理规划结构设计,避免因滥用而导致潜在问题的发生。 ---
评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值