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

首先看官方文档对Vue.use的使用说明在Vue中通过Vue.use注册全局组件的原理_第1张图片
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
}

你可能感兴趣的:(在Vue中通过Vue.use注册全局组件的原理)