使用gulp将多个特定文件和文件夹复制到另一个目录

时间:2017-05-09 10:13:29

标签: javascript gulp

我正在尝试使用gulp.srcgulp.dest从我的基本目录.复制多个文件和文件夹到新的子目录dist

基目录是Symfony项目的根目录。

这是我的gulpfile:

var files = [
  './app**/*.*',
  './bin**/*.*',
  './src**/*.*',
  './tests**/*.*',
  './var/',
  './vendor/',
  './composer.json']

gulp.task('distribute', function() {
  return gulp.src(files , { base: '.' }).pipe(gulp.dest('./dist'));
});

我只是不明白,为什么这不起作用。结果,我得到一个dist文件夹,其中包含指定文件夹的内容。因此,appbinsrc等作为根文件夹丢失。

1 个答案:

答案 0 :(得分:5)

自行移动目录

根据Use gulp to select and move directories and their files./选项使用base,并确保路径正确无误:

var files = [
  './app/**/*.*',
  './bin/**/*.*',
  './src/**/*.*',
  './tests/**/*.*',
  './var/',
  './vendor/',
  './composer.json'
];

gulp.task('distribute', function() {
  return gulp.src(files , { base: './' })
    .pipe(gulp.dest('dist'));
});

移动每个目录中的文件

请勿使用base选项并稍微更改路径。

var files = [
  'app/**/*.*',
  'bin/**/*.*',
  'src/**/*.*',
  'tests/**/*.*',
  'var/',
  'vendor/',
  'composer.json'
];

gulp.task('distribute', function() {
    return gulp.src(files)
        .pipe(gulp.dest('./dist'));
});

将每个目录威胁为任务的灵活方式

如果您想自己移动文件夹,只需使用任务生成器功能为每个文件夹创建一个任务。

function moveDirTask(dir, dest) {
    return function() {
        return gulp.src(`${dir}/**/*`)
            .pipe(gulp.dest(`${dest}/${dir}/`));
    };
}

gulp.task('move-app', moveDirTask('app', 'dest'));
gulp.task('move-bin', moveDirTask('bin', 'dest'));
gulp.task('move-src', moveDirTask('src', 'dest'));
gulp.task('move-tests', moveDirTask('tests', 'dest'));
// etc.

gulp.task('distribute', [
    'move-app',
    'move-bin',
    'move-src',
    'move-tests'
    // etc.
], function() {
    return gulp.src('composer.json')
        .pipe(gulp.dest('dest'));
});