Gulp .src() 匹配模式详解

  • 语法:gulp.src(globs[, options])
  • 匹配模式
    • 单匹配模式
    • 多匹配模式(同时使用多种匹配)
      • 1. 类正则
      • 2. 数组
      • 3. 展开模式

语法:gulp.src(globs[, options])

  • globs:文件匹配模式(类似正则表达式),用来匹配文件路径(包括文件名)
  • options:为可选参数。通常情况下我们不需要用到
gulp.src('**/*.js')

匹配模式

Gulp 内部使用了 node-glob 模块来实现其文件匹配功能

单匹配模式

匹配符 code 匹配 不匹配 备注
* * a.bx.yabcabc/ a/b.js 不匹配/,除非/出现在末尾
*.* a.bx.y abc 匹配所有带后缀的文件
*/*/*.js a/b/c.jsx/y/z.js a/b.jsa/b/c/d.js 匹配固定层级目录
** ** abca/ba/b.jsa/b/ca/b/c.js 匹配所有的目录和文件
**/*.js a.jsa/b.jsa/b/c.js 匹配所有目录下的 .js 文件
a/**/z a/za/b/za/b/c/za/b/c/d/z
a/**b/z a/b/za/nb/z a/c/nb/z ** 单独出现才能匹配多级目录
? ?.js a.jsb.jsc.js 占位符匹配,不匹配 /
a?? a.babc ab/ 占位符与字符搭配使用
[] [abc].js a.jsb.jsc.js ab.jsxyz.js 整个 [] 只匹配一个字符
[^abc].js
[!abc].js
x.jsy.js a.jsb.jsc.js 排除匹配字符

多匹配模式(同时使用多种匹配)

1. 类正则

表达式 备注
!(pattern|pattern|pattern) 匹配任何与括号中给定的任一模式都不匹配的
?(pattern|pattern|pattern) 匹配括号中给定的任一模式0次或1次,类似于js正则中的 (pattern|pattern|pattern)?
+(pattern|pattern|pattern) 匹配括号中给定的任一模式至少1次,类似于js正则中的 (pattern|pattern|pattern)+
*(pattern|pattern|pattern) 匹配括号中给定的任一模式0次或多次,类似于js正则中的 (pattern|pattern|pattern)*
@(pattern|pattern|pattern) 匹配括号中给定的任一模式1次,类似于js正则中的 (pattern|pattern|pattern)

2. 数组

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

3. 展开模式

{} 作为定界符,根据它里面的内容,会展开为多个模式,
最后匹配的结果为所有展开的模式相加起来得到的结果 !
1. a{b, c}d 展开为:abcacd
2. a{b,}c 展开为:abcac
3. a{0..3}c 展开为:a0ca1ca2c
4. a{b, c{d, e}f}g 展开为:abgacdfgacefg
5. a{b, c}d{e, f}g 展开为:abdegacdegabdegabdfg

你可能感兴趣的:(工具,Helper)