前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >require.context批量引入文件

require.context批量引入文件

作者头像
WahFung
发布2020-08-24 15:09:25
2.3K0
发布2020-08-24 15:09:25
举报
文章被收录于专栏:前端技术分享

require.context 是什么

require.context 是由webpack内部实现,require.context在构建时,webpack 在代码中进行解析。

当需要引入文件夹内多个文件模块时,可以使用 require.context 自动化批量引入,而不用手动一条一条添加。

参数

require.context 函数接收三个参数

  • String 读取文件夹的路径
  • Boolean 是否遍历文件夹的子目录
  • RegExp 匹配文件的正则

如何使用

用我实际开发的场景来做例子,现在文件夹内有多个 api 文件,我需要将这些组合起来

api.js

代码语言:javascript
复制
//引入api文件夹下的api接口
let requireAll = require.context('./api', false, /\.js$/)
//requireAll.keys()为文件名数组; requireAll(apiName)获取文件暴露的内容
const apiArr = requireAll.keys().map(apiName=> requireAll(apiName).default || requireAll(apiName))
//组合接口
let api = apiArr.reduce((prev,curr)=> Object.assign(prev,curr), {})

export default api
代码语言:javascript
复制
ruquireAllApi(apiName).default 获取的是Es6规范暴露的内容(如:export default)
代码语言:javascript
复制
ruquireAllApi(apiName) 获取的是CommonJs规范暴露的内容(如:module.exports)
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • require.context 是什么
  • 参数
  • 如何使用
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档