在Vue中通过Vue.use注册全局组件的原理

首先看官方文档对Vue.use的使用说明在这里插入图片描述
Vue.use 会自动阻止多次注册相同插件,届时即使多次调用也只会注册一次该插件。这就十分类似于单例模式,但不是严格意义上的单例模式。
单例模式强调一个类只能够实例化一个对象,类和对象的数量关系应该是1:N。但是通过单例模式创建的对象和它的类之间却是1:1的关系。这里之所以说Vue.use使用了单例模式的设计理念,是因为组件在Vue上只被允许注册一次。

源码

//Vue规定引入的插件必须是对象或者函数。
 Vue.use = function (plugin: Function | Object) {

    //首先检查Vue对象当前的_installedPlugins属性是否存在,
    //如果存在,那就去判断已经注册的组件中是否包含即将要注册的组件。
    //如果是,那么直接结束,不用继续往下执行。附带说一下。在条件不满足的情况下,
    //Vue.use返回的不是null,而是this。注意我们是在Vue.use方法中使用this,因此this指向Vue。
    //返回this可以使用链式调用。
    
    const installedPlugins = (this._installedPlugins || (this._installedPlugins = []))
    if (installedPlugins.indexOf(plugin) > -1) {
      return this
    }

    // 每一个函数默认都有一个arguments参数,我们可以以数组下标的方式(arguments[0]),访问其中的参数,但是arguments并不是一个数组。但是接下来我们希望通过apply的方式将Vue.use的参数转嫁给plugin函数plugin.install或者plugin函数,因此必须将arguments转换成真正的数组,因为apply接收数组。
    const args = toArray(arguments, 1)
    args.unshift(this)
    if (typeof plugin.install === 'function') {
      plugin.install.apply(plugin, args)
    } else if (typeof plugin === 'function') {
      plugin.apply(null, args)
    }
    
    // 注册完成的以后,需要将已经注册的插件备份到installedPlugins当中。
    // 下一次重复注册的时候就直接返回。
    installedPlugins.push(plugin)
    return this
  }

辅助函数
/**
 * 将类似于数组的对象转换成数组对象。
 */
export function toArray (list: any, start?: number): Array<any> {
  start = start || 0
  let i = list.length - start
  const ret: Array<any> = new Array(i)
  while (i--) {
    ret[i] = list[i + start]
  }
  return ret
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值