glob容许使用规则,从而获取对应规则匹配的文件。这个glob工具基于javascript.它使用了 minimatch 库来进行匹配javascript
npm install glob
const glob = require('glob')
glob方法能够传入三个参数:java
一、须要进行匹配的文件的路径(有点相似于正则表达式)。 二、option可选项,也能够不填写。 三、回调函数,回调函数内部能够返回两个参数,一个是匹配成功后的结果会返回一个数组,若是没有匹配上不会报错会返回一个空数组,一个是失败后的结果。 示例 glob("**/*.js", options, function (er, files) { console.log(files) })
glob("./src/components/**/*.js", function (er, files) { console.log(files); return files }); // [ './src/components/index/index.js', // './src/components/news/n.js', // './src/components/news/news.js' ]
glob("./src/components/**/?.js", function (er, files) { console.log(files); return files }); //[ './src/components/news/n.js' ]
glob("./src/components/**/!(n|index).js", function (er, files) { console.log(files) }) // [ './src/components/news/news.js' ]
[...] :匹配一个字符的范围,相似于一个正则表达式的范围。若是范围的第一个字符是!或者,它匹配任何不在范围内的字符git
?(模式1|模式2|模式3):匹配所提供的模式的零或一个事件正则表达式
+(模式1|模式2|模式3):匹配所提供的模式的一个或多个事件。npm
*(a|b|c) :匹配所提供的模式的零个或多个事件。数组
@(pattern|pat*|pat?erN):匹配所提供的模式之一。异步
在上述案例中使用的都是异步请求,调用回调获得结果,其实glob也提供了同步返回结果的API ,在这里我只列举一个async
let pattern = './src/components/**/@(index|n|news).js'; console.log(glob.sync(pattern)); // [ './src/components/index/index.js', // './src/components/news/n.js', // './src/components/news/news.js' ]
globby,是基于 glob,并进一步获得了加强函数
(async () => { const paths = await globby(['images','photos'],{ expandDirectories: true }); console.log(paths); })();