阵列路径不能与gulp.task一起使用

时间:2015-12-31 19:27:31

标签: javascript node.js gulp gulp-concat

我有一个gulp任务,在更改时会对js文件进行concats和uglify。如果我只使用一个源,它就可以工作。我正在学习角度,并且希望它首先将模块连接起来,所以类似于:

https://medium.com/@dickeyxxx/best-practices-for-building-angular-js-apps-266c1a4a6917#.mujtfmj63

我正在使用:

gulp.task('scripts', function(){
    return gulp.src(path.gulp.paths.src + ['/**/module.js', '/**/*.js'])
    .pipe(concat('all.min.js'))
    .pipe(uglify())
    .pipe(gulp.dest(path.gulp.paths.dist));
  });

并且gulp任务运行但它不会创建all.min.js文件。如果我删除数组并使用它,它可以工作:

gulp.task('scripts', function(){
    return gulp.src(path.gulp.paths.src + '/**/*.js')
    .pipe(concat('all.min.js'))
    .pipe(uglify())
    .pipe(gulp.dest(path.gulp.paths.dist));
  });

我的目录设置为

public
 |  
 +-- modules
 |  |  
 |  +-- module.js
 +-- test.js

我做错了什么?

1 个答案:

答案 0 :(得分:1)

您正在尝试将gulp.src(我假设是一个字符串)添加到数组中。对于此操作,JavaScript首先将数组转换为字符串(请参阅https://stackoverflow.com/a/7124907)。假设您的字符串为'./public/**/module.js,/**/*.js',那么您最终传递给[path.gulp.paths.src + '/**/module.js', path.gulp.paths.src + '/**/*.js']的内容是return gulp.src(['/**/module.js', '/**/*.js'], {cwd: path.gulp.paths.src}) ... ,这不是有效路径。

您可以将字符串添加到数组的每个元素({{1}}),也可以使用cwd option将其设置为所有文件的基础:

{{1}}