前段时间在用workbox时,在做precache时,匹配模式基于的是Glob Pattern模式,于是就看了下相关文档。
下面翻译一下node-glob的使用,原文:https://github.com/isaacs/node-glob#glob-primer
Glob
像在shell里面,用*
等匹配模式来匹配文件。
Glob基于Javascript实现,使用minimatch
库进行匹配。
![2add91f7f79d1a4071c7155fa57f3b1a.gif](https://i-blog.csdnimg.cn/blog_migrate/8ddc91d5d0dd334fecd23930388fc940.gif)
使用
使用npm
安装
npm i glob
var glob = require("glob")
// options可选
glob("**/*.js", options, function (er, files) {
// files是匹配到的文件数组
// 如果`options`中的`nonull`为true, 当未发现时, files返回["**/*.js"]
// `er`是一个错误对象或者null
})
Glob 入门
"Glob"是一种模式,类似于在命令行中输入ls *.js
,或是在.gitignore
文件中写build/*
。
在解析路径模式时,大括号内使用逗号进行分隔,分隔部分可以包含/
,所以a{/b/c,bcd}
会被展开为a/b/c
和abcd
。
在匹配路径使用时,以下字符有一些特殊的作用:
*
:匹配单路径下的 0 个或 多个 字符串。?
:匹配一个字符串。[...]
:匹配指定范围内的字符串,类似于正则表达式中的[]
。如果[]
中的第一个字符串是!
或者^
,则匹配不在范围内的任意字符串。!(pattern|pattern|pattern)
:匹配与提供模式中不匹配的内容。?(pattern|pattern|pattern)
:匹配提供模式中的 0次 或 1次。+(pattern|pattern|pattern)
:匹配提供模式中的 1次 或 多次。*(a|b|c)
:匹配提供模式中的 0次 或 多次。@(pattern|pat*|pat?erN)
:匹配与提供模式中完全匹配的。**
:和*
一样,可以匹配路径中的 0个 或 多个,而且**
可以匹配当前目录和子目录。但无