IT俱乐部 JavaScript vue require.context全局注册组件的具体实现

vue require.context全局注册组件的具体实现

​ 作用:一个 Webpack 提供的 API 方法,通过 require.context() 函数可以获取一个上下文,通常用来简化大量频繁的引入组件操作。​

 require.context() 接收三个参数:

  • directory:要查找的目录路径
  • isFindSub?:是否查找子目录
  • regExp:要匹配的文件正则表达式
const req = require.context('./component',true,/.vue$/)

过程:require.context() 执行后会返回一个 req 对象,该 req 对象中存在有一个 keys() 方法成员,

keys() 文件路径数组
​ 作用:它会返回一个 require.context() 方法在指定目录下查找到的所有文件路径数组。

const req = require.context('./component',true,/.vue$/)

console.log(req.keys()) 
// ['./component/SvgIcon.vue','./component/Form/Login.vue','./component/Channel.vue'...]

req.keys().forEach(item => {
    ...
})

在拿到所有待注册组件的文件路径之后,便可以传给 req 对象本身进行一个 import 解构导出操作。

一、定义2个组件

scr/components/ComponentsA/index.vue

A组件
export default { name: 'ComponentA' }

scr/components/ComponentsB/BBB/BBBB/index.vue

B组件
export default { name: 'ComponentB' }

二、局部使用这两个组件

import ComponentA from '@/components/ComponentA' import ComponentB from '@/components/ComponentB/BBB/BBBB' export default { components: { ComponentA, ComponentB } }

三、全局注册组件

如果这2个组件是基础性的组件,项目中好多地方都要用到,可以注册成全局组件

src/requireAllComponents.js

import Vue from 'vue'

const componentsContext = require.context('@/components', true, /index.vue$/) // true表示递归查找 正则匹配index.vue文件

componentsContext.keys().forEach(item => {
  const componentConfig = componentsContext(item).default
  Vue.component(componentConfig.name, componentConfig) // 全局注册组件
})

main.js

import './requireAllComponents'

此时,便不再需要在每个组件中都引入这种基础组件了

到此这篇关于vue require.context全局注册组件的文章就介绍到这了,更多相关vue require.context全局注册组件内容请搜索IT俱乐部以前的文章或继续浏览下面的相关文章希望大家以后多多支持IT俱乐部!

本文收集自网络,不代表IT俱乐部立场,转载请注明出处。https://www.2it.club/navsub/js/11039.html
上一篇
下一篇
联系我们

联系我们

在线咨询: QQ交谈

邮箱: 1120393934@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部