require.content

// require.context

// 作用: 一个 webpack 的 api , 用来一次性导出多个文件 (例如: 1.全局注册组件 2.一次性导出api 3.统一导出store modules模块

// 接收三个参数 1.要搜索的文件夹目录 2.是否还应搜索它的子目录 3. 匹配文件的正则表达式

// <------ 全局注册组件 ------>

// 获取文件夹下除了exclude的所有组件
const requireFolderName = (files, exclude) => {
  // 定义一个对象用来装自定义组件
  const components = {}

  // 遍历文件夹去除不需要的文件
  const filterArr = files.keys().filter(item => exclude.indexOf(item) === -1)

  for (const url of filterArr) {
    // 拿到单个组件的实例对象
    const obj = files(url).default ? files(url).default : files(url)

    // 放入components对象中
    const urlArr = url.split('/')
    components[urlArr[urlArr.length - 2]] = obj
  }
  return components
}

// !!!! 下面三个参数自行修改 (1.要搜索的文件夹目录 2.是否还应搜索它的子目录 3. 匹配文件的正则表达式)
const files = require.context('@/commons', true, /^\.\/[\s\S]+\/index.vue$/)
const components = requireFolderName(files, 'index.js')

export default {
  install (Vue, options) {
    for (let key in components) {
      Vue.component(key, components[key])
    }
  }
}

// <------ 全局注册组件 ------>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值