0

我正在尝试使用 main-bower-files 编写基于 gulp 的应用程序。我想将我和供应商的所有资产文件复制到%build_dir%/assets文件夹,但字体文件应该复制到%build_dir%/assets/fonts。如果没有供应商文件,可以通过gulp.src.options.base选项轻松完成。但我不明白如何处理供应商文件。我现在有

gulp.task('assets', ['less'], function() {
    return gulp.src('src/less/fonts/*', {base: 'src/less'})
        .pipe(addSrc('src/assets/**.*'))
        .pipe(addSrc(mainBowerFiles(/.*woff|woff2|otf|ttf/, {includeDev: true})))
        .pipe(gulp.dest(buildDir + '/assets'));
});

但它将供应商字体复制到%build_dir%/assets。因此,理想的情况是将base编写为正则表达式,解析供应商字体的路径并获取/fonts之前的所有路径。怎么做?

供应商文件夹具有以下结构:

/bower_components
   /lib1
      /fonts
         font1.woff
   /lib2
      /fonts
         font2.otf
   /lib3
      /fonts
         font3.ttf
4

1 回答 1

1

因此,理想的情况是将 base 编写为正则表达式,解析供应商字体的路径并采用 /fonts 之前的所有路径。怎么做?

不可能。该base选项不支持正则表达式。只有字符串。

无论如何,您不需要该base选项。只需创建两个流,每个流都有自己的gulp.dest(). 然后使用合并这些流merge-stream

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

gulp.task('assets', ['less'], function() {
  return merge(
    gulp.src(['src/less/fonts/*'].concat(mainBowerFiles(/.*woff|woff2|otf|ttf/, {includeDev: true})))
        .pipe(gulp.dest(buildDir + '/assets/fonts')),
    gulp.src('src/assets/**.*')
        .pipe(gulp.dest(buildDir + '/assets')));
});

这也意味着您不再需要gulp-add-src

于 2016-08-01T16:32:19.700 回答