Gulp没有按预期复制所有文件

时间:2014-10-19 14:42:26

标签: javascript gulp

我尝试为我的个人网站项目创建gulpfile.js。我之前从未这样做过,但经过了一些试验和错误的反复尝试。它现在以可接受的方式工作。

即使经过1000次修改,唯一不起作用的是简单复制文件和文件夹。

var files = {
  data_src : [
    './files.json',
    'data/**/*.*'
  ],
  distribution_dest : '_distribution'
};

gulp.task('copy-data', function() {
  gulp.src(files.data_src, { base: './' })
    .pipe(gulp.dest(files.distribution_dest))
    .pipe(notify({message: 'Data copied for distribution!'}));
});

这应该将所有子文件夹和文件复制到gulp.dest。但它只复制了其中的一半,即使我更改了名称等,也会忽略一些文件夹。(没有特殊字符,与正确复制的一次相同的子文件夹结构......) - 没有任何效果。我无法看到任何模式。

运行gulp时没有错误消息。没有什么可以帮助我找到错误。

为什么某些文件夹或文件被排除在复制之外?


我使用base来保留文件夹/子文件夹结构;尝试使用和不使用' base' - >对复制过程没有影响。

我还改变了“复制数据”的位置。运行列表中的任务。实际上它是第一个运行的任务。无论是第一个还是最后一个,行为似乎都没有变化。

gulp.task('default', function() {
  gulp.run('copy-data', 'custom-sass', 'framework-sass', 'custom-js', 'framework-js', 'replace-tags', 'browser-sync');
    ... some watches ...
});

数据文件夹的结构如下所示:

./data
   |-doc
   |---content
   |---template
   |-img
   |---chart
   |---icon
   |---logo
   |---pattern
   |---people
   |---photo
   |---symbol
   |-----brandklassen
   |-----brandschutzzeichen
   |-----gebotszeichen
   |-----gefahrensymbole
   |-----rettungszeichen
   |-----verbotszeichen
   |-----verkehrsrechtzeichen
   |-----warnzeichen
   |---wallpaper

/data/doc并且所有子文件夹都可以。
/data/img/chart/data/img/people也可以。

/data/img/photo内,21张图片中只有14张被复制 带有子文件夹/data/img/symbol的{​​{1}}被完全忽略。

1 个答案:

答案 0 :(得分:31)

解决了我自己的问题!问题是由异步操作任务引起的。在继续之前添加return强制gulp以完成复制过程!

gulp.task('copy-data', function() {
    return gulp.src(files.data_src, { base: './' })
    .pipe(gulp.dest(files.distribution_dest))
    .pipe(notify({message: 'Data copied for distribution!'}))
});

现在所有图片都会被复制!