我想用'coffee'处理一些文件,添加一些js文件,concat和minify。
这不起作用,咖啡在常规js文件上失败:
gulp.task 'build-js', ->
gulp.src([
"bower_components/mbdev-core/dist/js/db.js"
"bower_components/mbdev-core/dist/js/utils.js"
"src/js/config/app.coffee"
"src/js/config/app-db.coffee"
"src/js/accounts/accounts.coffee"
"src/js/budget_items/budget_items.coffee"
"src/js/line_items/line_items.coffee"
"src/js/misc/misc.coffee"
"src/js/reports/report_generators.coffee"
"src/js/reports/reports.coffee"
])
.pipe(coffee()).on('error', gutil.log)
.pipe(concat('app.js'))
.pipe(gulp.dest('public/js'))
有没有办法在咖啡部分后添加文件?
答案 0 :(得分:54)
您不需要将文件添加到原始src,而只需使用咖啡“if”......
因此,请使用gulp-if
gulp.task('task', function() {
gulp.src('./stuff/*')
.pipe(gulpif(/[.]coffee$/, coffee()))
.pipe(gulp.dest('./dist/'));
});
有关gulp-if的更多信息,请参阅here。
答案 1 :(得分:17)
您应该以这种方式组合流:
es = require("event-stream")
es.concat(
gulp.src('*.coffee')
.pipe(coffee()),
gulp.src('*.js')
).pipe(concat('all.js'))
.pipe(gulp.dest('.'))
你可以在Using multiple sources in one task
看到关于此的官方指南如果您关心流中的订单,则应使用streamqueue
代替event-stream
答案 2 :(得分:14)
您可以使用gulp-add-src插件:
addsrc = require 'gulp-add-src'
gulp.task 'build-js', ->
gulp.src(['src/coffee/*.coffee'])
.pipe(coffee()).on('error', gutil.log)
.pipe(addsrc(['src/js/somefile.js', 'src/js/otherfile.js']))
.pipe(concat('app.js'))
.pipe(gulp.dest('public/js'))
答案 3 :(得分:11)
gulp.src流是passthroughs,因此您可以在管道中的任何位置添加它们
gulp.task 'build-js', ->
gulp.src([
"src/js/config/app.coffee"
"src/js/config/app-db.coffee"
"src/js/accounts/accounts.coffee"
"src/js/budget_items/budget_items.coffee"
"src/js/line_items/line_items.coffee"
"src/js/misc/misc.coffee"
"src/js/reports/report_generators.coffee"
"src/js/reports/reports.coffee"
])
.pipe(coffee()).on('error', gutil.log)
.pipe(gulp.src([
"bower_components/mbdev-core/dist/js/db.js"
"bower_components/mbdev-core/dist/js/utils.js"
]))
.pipe(concat('app.js'))
.pipe(gulp.dest('public/js'))