Gulp globs匹配规则

2021-07-28  本文已影响0人  暖A暖

本节我们来学习 Gulp 中的 globs 的匹配规则。glob 是由普通字符或通配字符组成的字符串,用于匹配文件路径。我们可以使用一个或多个 glob 匹配规则在文件系统中定位文件。

gulp.src()方法

src() 方法需要一个 glob 字符串或一个 glob 字符串组成的数组来作为参数,确定哪些文件需要被操作。

gulp.src(globs[, options])
示例:
gulp.src('./js/*.js')                        // * 匹配js文件夹下所有.js格式的文件
gulp.src('./js/**/*.js')                     // ** 匹配js文件夹的0个或多个子文件夹
gulp.src(['./js/*.js','!./js/index.js'])     // ! 匹配除了index.js之外的所有js文件
gulp.src('./js/**/{omui,common}.js')         // {} 匹配{}里的文件名

匹配模式

gulp 内部使用了 node-glob 模块来实现其文件匹配功能。我们可以使用下面这些特殊的字符来匹配我们想要的文件。

单匹配模式:

匹配符 描述
* 匹配文件路径中的 0 个或多个字符,但不会匹配路径分隔符,除非路径分隔符出现在末尾
** 匹配路径中的 0 个或多个目录及其子目录
匹配方括号中出现的字符中的任意一个
[...] 匹配方括号中出现的字符中的任意一个

多匹配模式,同时使用多种匹配:

表达式 描述
!(pattern|pattern|pattern) 匹配任何与括号中给定的任一模式都不匹配的
?(pattern|pattern|pattern) 匹配括号中给定的任一模式0次或1次
+(pattern|pattern|pattern) 匹配括号中给定的任一模式至少1次
*(pattern|pattern|pattern) 匹配括号中给定的任一模式0次或多次
@(pattern|pattern|pattern) 匹配括号中给定的任一模式1次

数组

如果有多种匹配模式时,我们可以在 src() 方法中使用数组。

gulp.src(['js/*.js', 'css/*.css', '*.html'])
gulp.src([*.js,'!b*.js']) // 匹配所有js文件,但排除掉以b开头的js文件
gulp.src(['!b*.js',*.js]) // 不排除任何文件,因为排除模式不能出现在数组的第一个元素中

此外,还可以使用展开模式。展开模式以花括号 {} 作为定界符,根据它里面的内容,会展开为多个模式,最后匹配的结果为所有展开的模式相加起来得到的结果。

展开的例子如下:

字符串片段与分隔符

字符串片段是指两个分隔符之间的所有字符组成的字符串,在 globs 中,分隔符永远是 / 字符,不区分操作系统,即使是在采用 \\ 作为分隔符的 Windows 操作系统中也是如此。在 globs 中,\\ 字符被保留作为转义字符使用。

示例:

如果 * 符号被转义,那么 * 将被作为一个普通字符使用,而不再是通配符:

'glob_with_uncommon_\\*_character.js'

避免使用 Nodepath 类方法来创建 globs,例如 path.join

Windows 中,由于 Node 使用 \\ 字符作为路径分隔符,因此将会产生一个无效的 globs。还要避免使用 __dirname__filename 全局变量,由于同样的原因,process.cwd() 方法也要避免使用。

const invalidGlob = path.join(__dirname, 'src/*.js');
上一篇 下一篇

猜你喜欢

热点阅读