如何在与管道输入相同的目录中设置gulp.dest()?

And*_*nov 33 gulp

我需要在每个目录中找到所有找到的图像进行优化并记录到其中,而无需单独设置每个文件夹的路径.我不明白如何做到这一点.

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('./'));
});
Run Code Online (Sandbox Code Playgroud)

And*_*nov 65

这是两个答案.
第一:它更长,灵活性更低,需要额外的模块,但它的工作速度提高了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);

});
Run Code Online (Sandbox Code Playgroud)

第二种解决方案:它灵活而优雅,但速度较慢.我更喜欢它.

return gulp.src('./pictures/**/*')
    .pipe(somethingToDo())
    .pipe(gulp.dest(function (file) {
        return file.base;
    }));
Run Code Online (Sandbox Code Playgroud)

  • @Rouz它已经可以使用未知的文件夹深度了。foo / ** / *表示foo及其子目录中任何级别的所有文件。两颗双星是多余的。 (2认同)

ddp*_*rrt 11

干得好:

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

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

Gulp将通配符或globstar中的所有内容都放入其虚拟文件名中.因此,您想要选择的所有部分(例如./images/)必须位于目标目录中.

  • @MarioAlbertoContreras一对就足够了."./images/**/*.jpg"和"./images/**/**/*.jpg"一样好." (3认同)

g.b*_*eze 7

您可以使用base参数:

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