当前位置:首页 » 《随便一记》 » 正文

Vue 混入(mixin)详细介绍(可复用性、全局混入)_前端不释卷leo的博客

19 人参与  2022年03月27日 09:27  分类 : 《随便一记》  评论

点击全文阅读


基础

混入(mixin)提供了一种非常灵活的方式,来分发 Vue 组件中的可复用功能。一个混入对象可以包含任意组件选项(如data、methods、mounted等等)。当组件使用混入对象时,所有混入对象的选项将被“混合”进入该组件本身的选项。 

基本使用

1、定义一个混入(mixin)

let mixin = {
  created() {
    console.log("我是mixin里面的created!")
  },
  methods: {
    hello() {
      console.log("hello from mixin!")
    }
  }
}

export default mixin

2、在组件(Home.vue)中使用

<template>
  <div class="home">
    <span>This is a Home page</span>
  </div>
</template>

<script>
import myMixins from "../mixins";   //导入混入(mixin)
export default {
  name: 'Home',
  mixins: [myMixins]     //使用混入(mixin)
}
</script>

注意观察Home组件里面,并没有任何的生命周期钩子或者方法,但是打开页面之后查看控制台,却打印了内容,这就是混入对象中的created钩子中的console.log()。

现在,在Home组件加上mounted生命周期钩子

<template>
  <div class="home">
    <span>This is a Home page</span>
  </div>
</template>

<script>
import myMixins from "../mixins";
export default {
  name: 'Home',
  mixins: [myMixins],
  mounted(){         
    this.hello()     //在该组件中并没用定义hello方法,使用的是混入中的hello
  }
}
</script>

刷新页面,查看控制台打印信息

非但没报错, 还打印出了混入对象中定义的hello方法,即执行了混入对象中的mounted生命周期钩子,也验证了当前组件中合并了混入对象中定义的选项和方法。这就是混入的基本使用。

选项合并

当组件和混入对象含有同名选项时,这些选项将以恰当的方式进行“合并”。数据对象在内部会进行递归合并,并在发生冲突时以组件数据优先。

如下,我们在Home.vue中定义与混入对象中同名的选项

mixin.js

Home.vue 

刷新页面,查看控制台打印信息

此时,同名的created生命周期钩子进行了合并,合并为一个数组,因此都将被调用。另外,混入对象的钩子将在组件自身钩子之前调用。而methods中的hello方法因为冲突,在合并时保留组件中的hello,即优先当前组件的选项,因此打印的是“hello from Home!”。

值为对象的选项,例如 methodscomponents 和 directives,将被合并为同一个对象。两个对象键名冲突时,取组件对象的键值对。

可复用性

开篇提过,混入对象可成为一个可复用功能,我们在另外的组件中引入已定义的混入对象,可实现同样的逻辑与功能。

如在另外一个组件About.vue使用该混入对象

<template>
  <div class="about">
    <span>This is an About page</span>
  </div>
</template>

<script>
import myMixins from "../mixins";
export default {
  name: "About",
  mixins: [myMixins]
};
</script>

刷新页面,进行切换,查看控制台打印信息

混入对象中的console.log均被执行了,实现了逻辑或功能的复用。

那么有个问题,如果很多个组件同时使用同一个混入对象,这时候都要重复一个步骤,就是先导入混入对象,然后再使用,类似如下

<script>
import myMixins from "../mixins";
export default {
  mixins: [myMixins]
};
</script>

这样未免有点繁琐,且代码冗余,此时我们可以使用全局混入来优化这个问题。

全局混入

混入也可以进行全局注册。使用时格外小心!一旦使用全局混入,它将影响每一个之后创建的 Vue 实例。使用恰当时,这可以用来为自定义选项注入处理逻辑。

在main.js中通过Vue.mixin()引入混入对象即可全局使用(作用于该Vue实例下的所有组件)

import mixin from './mixins';
Vue.mixin(mixin)

此时我们将Home.vue、About.vue中使用混入对象的代码注释

刷新页面,进行切换,查看控制台打印信息

效果与在每个组件中单独引入混入对象相同,这便是全局混入。

请谨慎使用全局混入,因为它会影响每个单独创建的 Vue 实例 (包括第三方组件)。大多数情况下,只应当应用于自定义选项,就像上面示例一样。推荐将其作为插件发布,以避免重复应用混入。


点击全文阅读


本文链接:http://m.zhangshiyu.com/post/36811.html

混入  组件  对象  
<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 身份的鸿沟,数不清的误会:+后续+番外桑南星顾彦珩无删减小说在线无广告高口碑小说
  • 苏南初沈璟之是什么小说(纵她玩,纵她闹,纵她谋权篡位)(苏南初沈璟之)全本完整清爽版在线+无广告结局
  • 新章速递姜昕如是什么小说(儿子帮小三抢老公?我转身带出天才儿童)完本阅读无广告(姜昕如)
  • 凰九歌小说全篇完整在线阅读(剜心弃徒?呵,涅槃凰主杀回来了!)热门章节列表
  • 高分_夏晚歌陆秋(震惊!玄学大佬被读心了)(夏晚歌陆秋)全本完整阅读
  • 空有相思无尽处小说(燕婉娴容珩)后续+番外精编之作无删减_(燕婉娴容珩)空有相思无尽处小说结局+番外看点十足_笔趣阁
  • 大盛的繁荣景象尽收于眼底孟莹姝陆鼎鸿小说无删减阅读无干扰(孟莹姝陆鼎鸿)番外+续集
  • (头条)竹马抑郁后,未婚妻疯狂报复我小说(沈星眠陆景行)整本免费版阅读无广告(竹马抑郁后,未婚妻疯狂报复我)
  • 与君来生再相爱后续+完结_小说后续在线阅读_无删减免费完结_
  • 却道无情胜有情后续更新+番外_墨宸灵珠阿宸内容精选_小说后续在线阅读_无删减免费完结_
  • 新章速递可我不想再等你了是什么小说(沈疏月傅沉舟)完本阅读无广告(可我不想再等你了)
  • 春风不渡无心人最后结局(林至南霍以峦)_春风不渡无心人最后结局

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1