如何在javascript中编写一个glob来排除和包含文件?

时间:2016-09-01 22:38:45

标签: javascript glob

我编写了以下代码行,其中包含一个用于从每个文件夹中排除文件的glob:

 var images = gulp.src(['src/**/*.{png,svg,jpg,gif}', '!src/styles/images/abc/*.svg',
    '!src/styles/images/pqr/*card*.svg', '!src/styles/images/def/*.svg', '!src/styles/images/xyz/*.svg',
    '!src/styles/images/*-16.svg', '!src/styles/images/*[!16].svg', '!src/styles/images/svg-16/*.svg', 
    '!src/styles/images/uvw/*.png']).pipe(gulp.dest('build'));

你可以看到我几乎到处都在重复src/styles/images。我怎样才能进一步简化这个全局?有没有其他方法可以让重复的路径变得通用并添加其余的路径?

非常感谢任何帮助和建议。

谢谢。

1 个答案:

答案 0 :(得分:2)

使用映射是我对此问题的看法

var src = ['src/**/*.{png,svg,jpg,gif}']
var stylesimages = [ 'abc/*.svg', 'pqr/*card*.svg', 'table/*.svg', 'xyz/*.svg', '*-16.svg', '*[!16].svg', 'svg-16/*.svg', 
    'uvw/*.png'].map(x => '!src/styles/images/' + x)

src = src.concat(stylesimages)

var images = gulp.src(src).pipe(gulp.dest('build'));