Как установить gulp.dest() в том же каталоге, что и входы на входе?

Мне нужно, чтобы все найденные изображения в каждом из каталогов были оптимизированы и записаны в них, не устанавливая путь к каждой папке отдельно. Я не понимаю, как это сделать.

var gulp = require('gulp');
var imageminJpegtran = require('imagemin-jpegtran');

gulp.task('optimizeJpg', function () {

return gulp.src('./images/**/**/*.jpg')
    .pipe(imageminJpegtran({ progressive: true })())
    .pipe(gulp.dest('./'));
});

Ответ 1

Вот два ответа.
Сначала:. Он длиннее, менее гибкий и нуждается в дополнительных модулях, но он работает на 20% быстрее и предоставляет журналы для каждой папки.

var merge = require('merge-stream');

var folders =
[
    "./pictures/news/",
    "./pictures/product/original/",
    "./pictures/product/big/",
    "./pictures/product/middle/",
    "./pictures/product/xsmall/",
    ...
];

gulp.task('optimizeImgs', function () {

    var tasks = folders.map(function (element) {

        return gulp.src(element + '*')
            .pipe(sometingToDo())
            .pipe(gulp.dest(element));

    });

    return merge(tasks);

});

Второе решение: Это гибкий и элегантный, но медленный. Я предпочитаю это.

return gulp.src('./pictures/**/*')
    .pipe(somethingToDo())
    .pipe(gulp.dest(function (file) {
        return file.base;
    }));

Ответ 2

Здесь вы идете:

gulp.task('optimizeJpg', function () {

    return gulp.src('./images/**/**/*.jpg')
        .pipe(imageminJpegtran({ progressive: true })())
        .pipe(gulp.dest('./images/'));
});

Gulp принимает все, что подстановочный знак или globstar в его имя виртуального файла. Таким образом, все части, которые вы знаете, вы хотите выбрать (например, ./images/), должны находиться в целевом каталоге.

Ответ 3

Вы можете использовать параметр base:

gulp.task('uglify', function () {
  return gulp.src('./dist/**/*.js', { base: "." })
    .pipe(uglify())
    .pipe(gulp.dest('./'));
});