gulp-change / gulp-newer + gulp-rename не работает
Я пытаюсь обойти минификацию, изменение размера и переименование уже обработанных изображений, и добавление "измененных gulp" ничего не изменило для меня; все файлы обрабатываются каждый раз. Вместо этого я попробовал "gulp-newer", но все же безуспешно.
Позже я выяснил - если я избавлюсь от gulp-rename, gulp-change отлично работает. С gulp-rename в задаче - нет. Но мне все равно нужно gulp-переименовать...
var gulp = require('gulp');
var changed = require('gulp-changed');
var imagemin = require('gulp-imagemin');
var pngquant = require('imagemin-pngquant');
var imageResize = require('gulp-image-resize');
var rename = require('gulp-rename');
var img_src = ['_img/**/*.jpg', '_img/**/*.png'];
var img_dest = '_site/img';
gulp.task('resize-xl', function () {
return gulp.src(img_src)
.pipe(changed(img_dest))
.pipe(imageResize({
width : 2048,
crop : false,
upscale : true,
sharpen: false,
quality: 1
}))
.pipe(imagemin({
progressive: true,
svgoPlugins: [{removeViewBox: false}],
use: [pngquant()]
}))
.pipe(rename(function (path) {
path.basename += "-2048";
}))
.pipe(gulp.dest(img_dest));
});
2 ответа
Вы также можете переименовать свой файл перед передачей измененного плагина, чтобы плагин получил исходный файл с новым именем:
gulp.task( 'resize-xl', function () {
return gulp.src( img_src )
// change name first
.pipe( rename( { suffix: '-2048' } ) )
.pipe( changed( img_dest ) )
// add here your image plugins: imageResize, imagemin, ..
.pipe( gulp.dest( img_dest ) );
} );
Все файлы обрабатываются каждый раз, потому что gulp-changed
(или же gulp-newer
) в вашей задаче проверьте наличие изменений в файлах с именами gulp.src(img_src)
, И так как есть в img_dest
dir нет файлов с оригинальными именами, задача будет выполнена для всех файлов в img_src
реж.
Чтобы решить эту проблему, вы можете использовать промежуточный каталог для измененных файлов. Например:
1) Создайте новый каталог, _resize.
2) Изменить gulpfile.js:
var img_resize = '_resize';
gulp.task( 'resize-xl', function () {
return gulp.src( img_src )
.pipe( changed( img_resize ) )
// add here your image plugins: imageResize, imagemin, ..
// save the modified files with original names on '_resize' dir
.pipe( gulp.dest( img_resize ) )
.pipe( rename( { suffix: '-2048' } ) )
// save the modified files with new names on destanation dir
.pipe( gulp.dest( img_dest ) );
} );
После первого запуска эта задача будет обрабатывать только новые и измененные файлы