0

我正在将 Bower 添加到已经使用 Gulp 的项目中。我的文件夹结构如下:

 |- bower_components
 |   |- dependency1
 |   |   |- dist
 |   |       |- lib1.js
 |   |       |- lib1.min.js
 |   |
 |   |- dependency2
 |       |- core
 |           |- sub
 |           |   |- extra.js
 |           |
 |           |- lib2.js
 |
 |- target
     |- js

我已经设法使用main-bower-filesbower-normalize将所有 3rd 方库复制到 target/js 。但它是扁平的(而且我没有将 bower-normalize 选项设置flatten为 true!),所以它看起来像:

target
 |- js
     |- lib1.js
     |- extra.js
     |- lib2.js

Files lib1.jsextra.js并在 bower.json 配置文件lib2.js中标记。main

我想要实现的是具有如下文件结构:

target
 |- js
     |- dependency1
     |   |- lib1.js
     |
     |- dependency2
         |-  sub
         |    |- extra.js
         |
         |-  lib2.js

我将非常感谢您的帮助!

4

1 回答 1

1

通过gulp-flatten,这将帮助您删除或替换文件的相对路径。而且,我强烈推荐 wiredep。它会自动为您处理所有 bower 依赖项,以及依赖项的顺序。希望这会帮助你。

您的带有凉亭组件的源目录:

 |- bower_components
 |   |- dependency1
 |   |   |- dist
 |   |       |- lib1.js
 |   |       |- lib1.min.js
 |   |
 |   |- dependency2
 |       |- core
 |           |- sub
 |           |   |- extra.js
 |           |
 |           |- lib2.js
 |
 |- target
     |- js

使用 gulp-flatten -

gulp.src(['bower_components/**/*.js'])
  .pipe(flatten({ includeParents: [1, 1]} ))
  .pipe(gulp.dest('build/'));

将创建这个结构(从上面的树目录):

|- bower_components
|   |- dependency1
|   |   |- lib1.js
|   |
|   |- dependency2
|            |-  sub
|            |    |- extra.js
|            |
|            |-  lib2.js

includeParents: [1, 1]如果作为两个数字的数组传递,则顶部和底部的父级都将保留在文件的结果路径中。

includeParents: 1如果作为正数传入,它将在输出中包含顶级父级的数量。

includeParents: -1如果作为负数传入,它将在输出中包含底层父级的数量。

于 2016-12-11T01:29:07.140 回答