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

首先看官方文档对Vue.use的使用说明
《在Vue中通过Vue.use注册全局组件的原理》
将插件注册到Vue对象上,而且只能注册一次。这就十分类似于单例模式,但不是严格意义上的单例模式。
单例模式强调一个类只能够实例化一个对象,类和对象的数量关系应该是1:N。但是通过单例模式创建的对象和它的类之间却是1:1的关系。这里之所以说Vue.use使用了单例模式的设计理念,是因为组件在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
}
    原文作者:洛神赋
    原文地址: https://segmentfault.com/a/1190000019905739
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞