如果我理解正确,应该这样做:
var concat = require('gulp-concat');
gulp.task('minify-js', function() {
return gulp.src([ 'static/src/*.js', 'editing.js' ])
.pipe(concat('editing.min.js'))
.pipe(uglify())
.pipe(gulp.dest('static/dist/'));
});
如您所见,无需重命名,因为gulp-concat
已经要求您指定输出文件名。
编辑:这是另一种看法。它监视对任何.js
文件的更改(有一些排除;而不是使用**/*.js
您可以指定源文件所在的特定目录以限制可能匹配的数量)。当文件更改时,它将连接base*.js
文件和更改的文件,并使用更改文件的文件名作为缩小文件名的基础(foo.js
→ foo.min.js
):
var gulp = require('gulp');
var path = require('path');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
gulp.task('minify-js', function() {
// Watch for changes on JS files, but exclude some of them.
return gulp.watch([
'**/*.js',
'!static/src/base*.js',
'!node_modules/',
], function(ev) {
// Watch for changes to the files.
if (ev.type !== 'changed') return;
// Determine 'minified' filename.
var basename = path.basename(ev.path);
var extname = path.extname(basename);
var minname = basename.replace(extname, '.min' + extname);
// Run the uglify chain.
return gulp.src([ 'static/src/base*.js', ev.path ])
.pipe(concat(minname))
.pipe(uglify())
.pipe(gulp.dest('static/dist/'));
});
});