美文网首页
gulp路径的匹配规则

gulp路径的匹配规则

作者: 贫下码农 | 来源:发表于2018-07-19 19:49 被阅读0次

    title: gulp路径的匹配规则
    date: 2017-06-05 15:51:14
    tags: gulp 正则匹配


    gulp匹配规则

    Gulp使用 node-glob 模块,借助 minimatch 库,将glob表达式(glob expressions)转换成JavaScript正则表达式(JavaScript RegExp) ,从而实现文件匹配功能。我们所看到的 *** 都是其所提供的语法:

    * 匹配文件路径中的0个或多个字符,但不会匹配路径分隔符,除非路径分隔符出现在末尾。

    ** 匹配路径中的0个或多个目录及其子目录,需要单独出现,即它左右不能有其他东西了。如果出现在末尾,也能匹配文件。

    ? 匹配文件路径中的一个字符(不会匹配路径分隔符)。

    [...] 匹配方括号中出现的字符中的任意一个,当方括号中第一个字符为 ^!时,则表示不匹配方括号中出现的其他字符中的任意一个。

    !(pattern|pattern|pattern) 匹配任何与括号中给定的任一参数一致的都不匹配的。

    ?(pattern|pattern|pattern) 匹配括号中给定的任一参数0次或1次。

    +(pattern|pattern|pattern) 匹配括号中给定的任一参数至少1次。

    *(a|b|c) 匹配括号中给定的任一参数0次或多次。

    @(pattern|pat*|pat?erN) 匹配括号中给定的任一参数1次。

    用实例来加深理解:

    * 能匹配 a.js , x.y , abc , abc/ ,但不能匹配 a/b.js

    *.*
    
    a.js
    
    style.css
    
    a.b
    
    x.y
    
    */*/*.js
    
    a/b/c.js
    
    x/y/z.js
    
    a/b.js
    
    a/b/c/d.js
    

    ** 能匹配 abc , a/b.js , a/b/c.js , x/y/z , x/y/z/a.b ,能用来匹配所有的目录和文件

    **/*.js
    
    foo.js
    
    a/foo.js
    
    a/b/foo.js
    
    a/b/c/foo.js
    
    a/**/z
    
    a/z
    
    a/b/z
    
    a/b/c/z
    
    a/d/g/h/j/k/z
    

    a/**b/z 能匹配 a/b/z , a/sb/z ,但不能匹配 a/x/sb/z ,因为只有单 **单独出现才能匹配多级目录

    ?.js
    
    a.js
    
    b.js
    
    c.js
    

    a?? 能匹配 a.b , abc ,但不能匹配 ab/ ,因为它不会匹配路径分隔符

    [xyz].js 只能匹配 x.js , y.js , z.js ,不会匹配 xy.js , xyz.js 等,整个中括号只代表一个字符

    [^xyz].js 能匹配 a.js , b.js , c.js 等,不能匹配 x.js , y.js , z.js

    当有多种匹配模式时可以使用数组:

    // 使用数组的方式来匹配多种文件
    gulp.src(['js/*.min.js','sass/*.min.css'])
    

    使用数组的方式还有一个好处就是可以很方便的使用排除模式,在数组中的单个匹配模式前加上 ! 即是排除模式,它会在匹配的结果中排除这个匹配,要注意一点的是不能在数组中的第一个元素中使用排除模式:

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

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

    a{b,c}d
    
    abd,acd
    
    a{b,}c
    
    abc,ac
    
    a{0..3}d
    
    a0d
    
    a1d
    
    a2d
    
    a3d
    
    a{b,c{d,e}f}g
    
    abg
    
    acdfg
    
    acefg
    

    a{b,c}d{e,f}g 会展开为 abdeg , acdeg , abdeg , abdfg

    6. 注意事项(Attention)

    • watch 的时候路径不要用 './path',直接使用 '/path' 即可不然会导致新增文件无法被 watch。
    • gulp 对于 one after one 的任务链,需要加 return,比如 gulp clean

    来自
    http://blog.csdn.net/cy5849203/article/details/52092566

    相关文章

      网友评论

          本文标题:gulp路径的匹配规则

          本文链接:https://www.haomeiwen.com/subject/vehxmftx.html