我尝试为我的个人网站项目创建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}}被完全忽略。
答案 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!'}))
});
现在所有图片都会被复制!