require.context实现前端工程化
一、require.context是什么
一个webpack的api,通过只想require.context函数获取一个特定的上下文,主要用来实现自动化到入模块,在前端工程周昂,如果遇到从一个文件夹引入很多模块的情况下,可以使用这个api,他会遍历文件夹中的指定文件,然后自动导入,使得不需要每次显式的调用import导入模块
二、分析require.context
require.context函数接收三个参数
1.directory{string}-读取文件的路径
2.useSubdirectories{Boolean}-是否便利文件的子目录
3.regExp{ewgExp}-匹配文件的正则
语法: require.context(directory, useSubdirectories = false, regExp = /^.//);
返回值:
值得注意的是require.context函数执行后返回的是一个函数,并且这个函数有3个属性
-
resolve {Function} -接受一个参数request,request为test文件夹下面匹配文件的相对路径,返回这个匹配文件相对于整个工程的相对路径
-
keys {Function} -返回匹配成功模块的名字组成的数组
-
id {String} -执行环境的id,返回的是一个字符串
三、用途
1.vue全局注册组件
在项目中,我们都会针对项目的功能,将项目中高频出现的部分写成组件方便调用,这时候我们使用require.context完成组件的注册,省去在每个页面进行import的工作
比如:我们把组件全部写入components文件夹下,然后创建见componentRegiser.js使用require.context进行注册
function changStr(str){ return str.charAt(0).toUpperCase()+str.slice(1) } export default { install(Vue) { const requireAll=require.context("./components",false,/\.vue$/) requireAll.keys().forEach((item)=>{ Vue.component(changStr(item.replace(/\.\//,'').replace(/\.vue$/,'')),requireAll(item).default) }) } }
然后只要在main.js里引用这个js文件,然后vue.use()注册就可以在所有页面调用组件了,比如在components下创建helloWorld.vue组件,在页面中只需要<HelloWorld>这样就可以使用了
2.vue路由模块化
同理,也可以解决另一个问题,在vue项目中,路由文件会随着项目增大而增大,这时我们可以使用require.context进行模块化管理,
3.网络请求模块化管理
4.自定义指令模块化管理
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
2021-01-12 css学习day01