vue 2 中采用选项式API。学习笔如:data、混入methods、学习笔watch、混入computed以及生命周期钩子函数等等。学习笔 mixin 混入,混入提供了一种非常灵活的学习笔方式,来分发 vue 组件中的混入可复用功能,一个mixin 对象可以包含任意组件选项,学习笔当组件使用 mixin 对象时,混入所有的学习笔 mixin 对象的选项将被混入组件本身的选项。 通俗地讲,mixin 对象把一些组件公用的混入选项,如data内数据,学习笔方法、计算属性、生命周期钩子函数,单独提取出来,然后在组件内引入,就可以与组件本身的选项进行合并。 示例1: 就相当于: 这样做的好处就是可以把多个组件公共选项抽取到一个 mixin 对象内,需要的时候直接引入就可以了。 mixin 包含的选项,同时组件内也可以包含这些选项,如果 mixin 中包含的选项中,有部分属性相同怎么办?如 mixin 和组件内都存在一个同名方法时,如何处理?或者都包含生命周期钩子函数时,它们的执行顺序谁前谁后呢?接下来我们就看看,使用 mixin 时应该注意的点。 2.1、使用 mixin 对象时,组件内部和 mixin 包含相同选项,如何处理呢? 示例2:mixin 对象和实例都包含data选项,内部有两个不同的变量 运行后,我们发现两个变量都能使用,mixin 对象中的 data 与实例中的 data 选项进行合并了。对于 methods 、computed 也是一样的。 如果我们把上个实例中的两个变量,修改成同名时,会怎样呢? 2.2、使用的 mixin 对象选项 和实例中的选项拥有相同的云南idc服务商属性该如何处理? 示例3:data 内拥有相同的变量名 name 运行结果,name 值为 “前端人”。 属性值相同时,会选择就近原则,优先继承实例内的值,所以 mixin 对象的属性会被实例中的属性给覆盖掉。 2.3、mixin 对象也可以添加生命周期钩子函数,mixin 和 实例中 的那个优先执行呢? 示例4:mixin 加入生命周期钩子函数,以 mounted 为例 运行结果: 我们发现生命周期函数会合并执行,优先执行 mixin 中的, 然后再执行实例中的。 $options 用于当前组件实例 的初始化选项,需要在选项中包含自定义 property 时会有用处。 简单讲,$options 用于在实例中调用 mixin 自定义属性。 示例5:添加自定义属性 在实例中使用: 如果在实例中也包含一个同名自定义属性时,优先级会作何处理呢?如果我们想控制优先级又该如何处理呢? optionMergeStrategies 选项合并策略,使用 mixin 自定义属性和实例中的属性冲突时,使用optionMergeStrategies 定义合并规则的,服务器托管也就是优先使用谁的问题。 使用规则: 根据上述示例5,给实例中加 custom 属性,运行查看结果。 示例6:验证 mixin 和 实例 属性优先级 发现,mixin 对象中的属性值被实例中属性值覆盖掉了。我们可以借用上述的 optionMergeStrategies 属性,修改 custom 的合并规则。 在 main.js 文件内引入: 再次运行之后,我们发现打印结果变成 mixin 中的属性值了: console.log(this.$options.custom); // 打印结果:mixin custom 如果项目中有多个组件复用某些选项时,我们可以通过全局使用 mixin 对象。一个实例也可以引入多个 mixin 对象。语法如下:一、混入mixin 如何使用 ?学习笔
二、亿华云mixin 使用时注意点
三、mixin 自定义属性
四、合并策略
五、全局配置 mixin