为什么Gulp不会忽略该文件?

时间:2015-11-17 03:49:41

标签: node.js gulp frontend

我的项目结构:

build
public
    assets
        css
            app.css
            vendor.css
        js
            app.js
            vendor.js
    index.html
src
    assets
        styles
            main.styl
        coffee
            main.coffee
    index.jade

我有一个任务是在两个文件中构建一个Bower库:vendor.css和vendor.js:

var uglify = require('gulp-uglify');
var minifyCss = require('gulp-minify-css');
var mainBowerFiles = require('gulp-main-bower-files');
var filter = require('gulp-filter');
var concat = require('gulp-concat');
var connect = require('gulp-connect');

gulp.task('bower', ['clean'], function () {
  var jsFilter = filter('**/*.js', { restore: true });
  var cssFilter = filter('**/*.css', { restore: true });

  return gulp.src('./bower.json')
    .pipe(mainBowerFiles())
    .pipe(cssFilter)
    .pipe(concat('vendor.css'))
    .pipe(minifyCss())
    .pipe(gulp.dest(path.dist.css))
    .pipe(cssFilter.restore)

    .pipe(jsFilter)
    .pipe(concat('vendor.js'))
    .pipe(uglify())
    .pipe(gulp.dest(path.dist.js))
    .pipe(jsFilter.restore)

    .pipe(connect.reload());
});

这是我在更改src文件夹中的文件时清除临时文件夹的任务:

var del = require('del');
...
gulp.task('clean', function () {
  return del(['build', 'public/**', '!public/**/vendor.{js,css}']);
});

必须删除build文件夹和公共目录的所有内容,但public.catus / assets / css和public / assets / js文件夹中的vendor.css和vendor.js除外。

这样做是为了在文件的每次更改时都不构建凉亭库,因为它需要3-4秒(顺便说一句,这是正常的吗?),但仅在第一次启动或更换凉亭时。 json(运行单独的观察者)。

但不知何故,文件vendor.js和vendor.css也被删除了。使用gulp-tap我得到了一个文件列表: List of files

我做错了什么?

1 个答案:

答案 0 :(得分:0)

根据https://github.com/sindresorhus/del#beware,您还需要排除子目录,否则del将删除所有子目录。

所以,你可以使用这样的东西:

del([.., 'public/**/*', '!public/{dir_1,dir_2}', '!test/**/vendor{.css,.js}']);