0

如果我这样做:

var gulp = require('gulp');
var replace = require('gulp-replace');
var rename = require('gulp-rename');

gulp.task('TaskExample', function ReplaceExampleFileTokens() {

    return gulp.src('./src/' + 'ExampleFileTokens.config')

        .pipe(replace('#{String}#', 'Hello World'))
        .pipe(rename('ExampleFile.config'))
        .pipe(gulp.dest('./dest'));
    });

我会:

  1. ExampleFileTokens.config然后替换令牌

  2. 将其重命名为ExampleFile.config

  3. 最后存入'./dest'

我的问题如下:

  • 如果令牌不存在,你将如何#{String}#在 不使用 gulp.dest 的情况下检查它的存在?ExampleFileTokens.config

  • 我知道我可以使用令牌在 javascript 中搜索文件,但是有没有办法可能gulp-replace,因为它已经在搜索和替换我的令牌?

4

1 回答 1

1

我认为没有办法让 gulp-replace 完成您想要的所有工作。在流中设置条件很麻烦。

不过,您可以使用过滤器轻松完成此操作(gulp-filter

const gulp = require('gulp');
const replace = require('gulp-replace');
const rename = require('gulp-rename');

const filter = require('gulp-filter');
const filterEach = require('gulp-filter-each')

gulp.task("TaskExample", function () {

  // return true if want the file in the stream
  // const configFilter = filter(function (file) {       
  //   let contents = file.contents.toString();
  //   return contents.match('#{String}#');
  // });

  return gulp.src('./src/' + 'ExampleFileTokens.config')

    // you can use either of the following two filters
    // .pipe(configFilter)
    .pipe(filterEach(content => content.match('#{String}#')))

    .pipe(replace('#{String}#', 'Hello World'))
    .pipe(rename('ExampleFile.config'))
    .pipe(gulp.dest('./dest'));
});
于 2018-05-04T04:19:36.573 回答