require.context(directory:String, includeSubdirs:Boolean /* 可选的,默认值是 true */, filter:RegExp /* 可选的 */)
得到的是一个函数实例:
ƒ webpackContext(req) {
var id = webpackContextResolve(req);
return __webpack_require__(id);
}
ƒ webpackContext(req)
keys: ƒ webpackContextKeys()
resolve: ƒ webpackContextResolve(req)
id: "./src/project sync recursive routers.js$"
具体这个应该叫做什么我也不太清楚。
它有keys和resolve两个方法,keys方法执行后返回的是所有匹配的文件的相对路径(相对于传入require.context方法的第一个参数的路径)。取一个key作为参数执行那个函数实例,即可得到对应模块文件导出的东西。
示例:
const routerList = require.context('../project/', true, /routers.js$/);
console.log(routerList);
console.log(routerList.keys());
routerList.keys().forEach(k => {
console.log(routerList(k));
});
所输出内容为:

至于它的resolve方法,暂时不知道是干嘛用的。
网友评论