2

运行gulp-jscs插件以使用以下任务分析我的代码没有问题。但是,当我添加时fix:true,文件中没有任何变化,并且 JSCS 现在就像它根本没有运行一样......当我删除传递给 JSCS 插件的对象并删除该gulp.dest()行时,它会报告代码样式问题。

因此,似乎传入fix:true或绑定写回固定文件会导致 JSCS 内部短路......想法?

var $ = require('gulp-load-plugins')({lazy: true});
gulp.task('vet', function () {
  log('Analyzing source with JSHint and JSCS');

  return gulp
    .src(config.allJs, {base: './'})
    .pipe($.jshint())
    .pipe($.jshint.reporter('jshint-stylish', {verbose: true}))
    .pipe($.jscs({fix:true}))
    .pipe(gulp.dest('./'));
});
4

1 回答 1

2

更新 2

我找到了一种更简单/更清洁的方法,只需指定基本参数

gulp.src(files, {base: './'})

然后 file.name 将包含完整路径,以便您可以输出到当前目录

gulp.dest('.')

所以最后:

gulp.src(files, {base: './'})
    .pipe(jscs({fix: true}))
    .pipe(jscs.reporter())
    .pipe(jscs.reporter('fail'))
    .pipe(gulp.dest('.'))
    .on('error', console.error.bind(console));

更新 1

我一直在用这段代码解决这个问题:

var gulp = require('gulp');
var jscs = require('gulp-jscs');
var foreach = require('gulp-foreach');
var rimraf = require('gulp-rimraf');

gulp.task('jscs', () => {
return gulp.src(['file1.js', 'file2.js'])
    .pipe(foreach((stream, file) => {
        return stream
            .pipe(jscs({ fix: true }))
            .pipe(jscs.reporter())
            //.pipe(jscs.reporter('fail'))
            .pipe(rimraf())
            .pipe(gulp.dest(file.base));
    }));
});

依赖项:

npm install --save-dev gulp gulp-rimraf gulp-foreach gulp-jscs

在全球范围内,gulp-foreach 使用自己的流迭代每个 src,rimraf 在写入vinyl.base 目标之前删除文件。

让我知道它是否有帮助。

于 2016-03-11T04:59:46.620 回答