5

jshintでタスクを2回実行したいのですがGruntJS、毎回異なるオプションを使用します。

どうすればそのようなことをすることができますか?

現在、私のようにGruntfile.js見えます:

'use strict';

module.exports = function(grunt) {
    var opts = {
        pkg: grunt.file.readJSON('package.json'),
        jasmine_node: {
            matchall: true,
            forceExit: true
        },
        jshint: {
            files: [
                'gruntfile.js',
                'src/**/*.js', '!src/static/bin', '!src/static/js/libs/*.js',
                'test/spec/**/*.js'
            ],
            options: {
                jshintrc: '.jshintrc'
            }
        }
    };

    grunt.initConfig(opts);

    grunt.loadNpmTasks('grunt-contrib-jshint');
    grunt.loadNpmTasks('grunt-jasmine-node');

    grunt.registerTask('default', ['jshint', 'jasmine_node']);
    grunt.registerTask('travis', ['jshint', 'jasmine_node']);
};

そして、私はおそらくそれを次のようなものにしたいと思います:

var jshint: {
    files: [
        'gruntfile.js',
        'src/**/*.js', '!src/static/**',
        'test/spec/**/*.js'
    ],
    options: {
        jshintrc: '.jshintrc'
    }
}

var jshint2 = {
    files: [
        'src/static/**/*.js',
        '!src/static/bin',
        '!src/static/js/libs/*.js'
    ],
    options: {
        jshintrc: '.jshintrc-browser'
    }
};

フロントエンドのJavaScriptとNodeJSのJavaScriptに異なるオプションを選択できるように、リンティングはこれらの環境ごとに異なる必要があるためです。

4

1 に答える 1

7

jshintマルチタスクです。したがって、次の設定が必要になる可能性があります。

jshint: {
  browser: {
    files: [
        'src/static/**/*.js',
        '!src/static/bin',
        '!src/static/js/libs/*.js'
    ],
    options: {
        jshintrc: '.jshintrc-browser'
    }
  },
  node: {
    files: [
        'gruntfile.js',
        'src/**/*.js', '!src/static/**',
        'test/spec/**/*.js'
    ],
    options: {
        jshintrc: '.jshintrc'
    }
  }
}

ブラウザバージョンを実行するには:

grunt jshint:browser

ノードバージョンまで実行するには:

grunt jshint:node

ただ実行している:

grunt jshint

両方を実行します。

もちろん、おそらく別のタスクを介してそれらをトリガーすることをお勧めします。

grunt.registerTask('build', ['clean:all', 'jshint:browser', ...]);

詳細については、「JSHintオプションとグローバルの指定」セクションをお読みください。

于 2013-03-19T18:24:55.880 に答える