如何让 gulp-jshint 忽略文件夹

How to get gulp-jshint to ignore folders

我继承的解决方案中有以下文件夹结构

.\gulp.config.js
.\gulpfile.js
.\.jscsrc
.\.jshintrc
.\default.js
.\Resources\js\main.js
.\Resources\js\modules\   various user created js files
.\Resources\js\vendor\    various js files i.e jQuery

我已经安装了 gulp-jscs 和 gulp-jshint。

我从 https://github.com/johnpapa/pluralsight-gulp/blob/master/.jscsrc 获取的 .jscsrc。

我在 gulpfile.js 中有以下内容:

'use strict'

var gulp = require('gulp');
var jshint = require('gulp-jshint');
var jscs = require('gulp-jscs');

gulp.task('verifyJS',function(){
    gulp.src([
        './Resources/**/*.js',
        './*.js'
    ])
    .pipe(jscs())
    .pipe(jshint())
    .pipe(jshint.reporter('jshint-stylish', { verbose: true }));
});

我正在尝试更新 .jscsrc 中的 excludeFiles 以排除以下内容:

.\default.js 
.\resources\js\vendor

这是我试过的:

 "excludeFiles": [
     "node_modules/**",
     "bower_components/**",
     "Resources/js/vendor/**", // vendor supplied files. ie jQuery
     "./Resources/js/vendor/**", 
     "default.js", 
     "/default.js", 
     "./default.js", 
 ],

我已经包含了我尝试过的所有组合。

但是当我 运行 gulp verifyJS 它仍然包含我想要排除的文件。

如何正确设置 excludeFiles 以排除项目根目录中的文件以及包含所有后续文件和文件夹的子文件夹?

gulp-jshint 不关心你的 .jscsrc 里有什么,因为那是 gulp-jscs 的配置文件。您需要一个 .jshintignore 文件。

以下是在 gulp-jscsgulp-jshint 中忽略供应商文件的方法:

.jscsrc

"excludeFiles": [
  "node_modules/**",
  "bower_components/**",
  "Resources/js/vendor/**",
  "default.js", 
],

.jshintignore

node_modules/**
bower_components/**
Resources/js/vendor/**
default.js

gulpfile.js

gulp.task('verifyJS', function(){
  return gulp.src([
    './Resources/**/*.js',
    './*.js'
  ])
  .pipe(jscs())
  .pipe(jscs.reporter()) // you forgot this
  .pipe(jshint())
  .pipe(jshint.reporter('jshint-stylish', { verbose: true }));
});