私が正しく理解していれば、次のようなことができるはずです:
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/'));
});
});