我的项目结构:
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
我做错了什么?
答案 0 :(得分:0)
根据https://github.com/sindresorhus/del#beware,您还需要排除子目录,否则del
将删除所有子目录。
所以,你可以使用这样的东西:
del([.., 'public/**/*', '!public/{dir_1,dir_2}', '!test/**/vendor{.css,.js}']);