全局组件批量注册

main.js中

//需要注册的组件名
let vueComponent = [];

// 自定义组件  
const requireComponents = require.context("@/components/", true, /\index.vue/);

// 遍历出每个组件的路径
requireComponents.keys().forEach((fileName) => {
  // 组件实例
  const reqCom = requireComponents(fileName);
  // 截取路径作为组件名
  const reqComName =
    reqCom.name || fileName.replace(/\.\/(.*)\/index.vue/, "$1");
  // 组件挂载
  if (vueComponent.includes(reqComName) == true) {
    Vue.component(reqComName, reqCom.default || reqCom);
  }
});

require.context(directory,useSubdirectories,regExp)

  1. directory:表示检索的目录
  2. useSubdirectories:表示是否检索子文件夹
  3. regExp:匹配文件的正则表达式,一般是文件名
    例如 require.context("@/views/components",false,/index.vue$/)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值