gulp-rename创建不必要的目录

时间:2015-12-02 14:49:13

标签: gulp gulp-rename

我正在使用gulp来调整大小并重命名一些图像:

var gulp = require('gulp');
var imageResize = require('gulp-image-resize');
var changed = require('gulp-changed');
var rename = require('gulp-rename');

var resizeImages = function resize(options) {
  gulp
    .src('original-images/**')
    .pipe(changed('./'))
    .pipe(imageResize({ width: options.width }))
    .pipe(rename((path) => { path.basename += options.fileSuffix; }))
    .pipe(gulp.dest('public/assets/img/'));
};


gulp.task('resize-images', () => {
  const desktopImageResizeOptions = {
    width: 356,
    fileSuffix: '-desktop',
  };
  const tabletImageResizeOptions = {
    width: 291,
    fileSuffix: '-tablet',
  };
  const phoneImageResizeOptions = {
    width: 721,
    fileSuffix: '-phone',
  };
  resizeImages(desktopImageResizeOptions);
  resizeImages(tabletImageResizeOptions);
  resizeImages(phoneImageResizeOptions);
});

这样做 - 它将已调整大小的重命名图像放入正确的位置,并将后缀添加到文件名中。

但是,它还会创建名为-desktop-phone-tablet的目录。我该如何防止这种情况发生?

2 个答案:

答案 0 :(得分:0)

我通过指定文件结尾解决了这个问题,因此没有传入目录。所以第8行的src变成了

.src('original-images/**/*.{jpg,png}')

答案 1 :(得分:0)

您还可以处理更复杂的案件。如果传递给rename函数的函数没有改变文件的路径,它将被省略。在以下示例中,如果文件没有extname

,则不会重命名该文件
.pipe(rename(function (path) {
    if (path.extname !== "") {
        path.basename += "-" + options.width;
    }            
}))