前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue入门系列(六)组件继承mixin

Vue入门系列(六)组件继承mixin

作者头像
娜姐
发布2021-01-14 10:42:48
1.1K0
发布2021-01-14 10:42:48
举报
文章被收录于专栏:娜姐聊前端娜姐聊前端

mixin在官网上的解释为"混合”-以组件使用混合对象时,所有混合对象的选项将被混入该组件本身的选项。

但是笔者觉得,如果从面向对象层面去解释,会更清楚些。我们知道,面向对象三大基本特征是:抽象,封装和继承。

组件,就是对功能的抽象,通过封装而成为完成某个特定功能的模块。Vue的宗旨是,组件是最小粒度,通过组合不同的组件,实现更加复杂的UI(与React一样)。

那么,如果组件之间有某些共性呢?这时,就应该用到继承。将通用的逻辑封装为功能模块,提供给不同组件使用。如果是Java,继承时通过extend父类/接口实现,在Vue中,并没有extend的关键字,但是,mixin可以完成类似效果,即复用/混合。

假设我们有两个下拉组件,核心代码,即列表生成,列表项选中等操作是完全一样的,只是显示效果不同。那么,可以采用如下方式实现继承关系:

代码语言:javascript
复制
// commonList.js
export default {
  props: {
    items: []
  }
  data(){
    return { selectedItem: null};
  }
  ...
}

//DropdownA.vue
import commonList from '.commonList';

export default {
  name: 'DropdownA',
  mixins: [commonList ]
}

//dropdownB.vue
import commonList from '.commonList';

export default {
  name: 'DropdownB',
  mixins: [commonList ]
}

如果组件和基类对象含有同名选项时:

  • 钩子函数: 混合为一个数组 ,基类对象的钩子将在组件自身钩子之前调用
  • 值为对象的选项: 如 methods, componentsdirectives,将被混合为同一个对象。 两个对象键名冲突时,取组件对象的键值对。
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档