15

我正在尝试遵循此说明https://webpack.js.org/loaders/jshint-loader/ 并收到错误消息:

我的配置文件:

const path = require('path');

    module.exports = {
      entry: {
        app: './index.js'
      },
      output: {
        filename: 'bundle.js',
        path: path.resolve(__dirname, 'dist')
      },

      module: {
        rules: [
          {
            test: /\.js$/, // include .js files
            enforce: "pre", // preload the jshint loader
            exclude: /node_modules/, // exclude any and all files in the node_modules folder
            use: [
              {
                loader: "jshint-loader"
              }
            ]
          }
        ]
      },

      // more options in the optional jshint object
      jshint: {
        // any jshint option http://www.jshint.com/docs/options/
        // i. e.
        camelcase: true,

        // jshint errors are displayed by default as warnings
        // set emitErrors to true to display them as errors
        emitErrors: false,

         // jshint to not interrupt the compilation
         // if you want any file with jshint errors to fail
         // set failOnHint to true
         failOnHint: false,

         // custom reporter function
         reporter: function(errors) { }
       }
    };

错误文字:

配置对象无效。Webpack 已使用与 API 模式不匹配的配置对象进行初始化。- 配置具有未知属性“jshint”。这些属性是有效的:object { amd?, bail?, cache?, context?, dependencies?, devServer?, devtool?, entry, externals?, loader?, module?, name?, node?, output?, performance? , plugins?, profile?, recordsInputPath?, recordsOutputPath?, recordsPath?, resolve?, resolveLoader?, stats?, target?, watch?, watchOptions? } 对于错别字:请更正。对于加载器选项:webpack 2 不再允许配置中的自定义属性。

4

2 回答 2

59

他们网站上的说明似乎已经过时,因为这确实不起作用。Github上有一个关于此的未解决问题。

此配置应该有效:

const path = require('path');

module.exports = {
  entry: {
    app: './index.js'
  },
  output: {
    filename: 'bundle.js',
    path: path.resolve(__dirname, 'dist')
  },

  module: {
    rules: [{
      test: /\.js$/, // include .js files
      enforce: "pre", // preload the jshint loader
      exclude: /node_modules/, // exclude any and all files in the node_modules folder
      use: [{
        loader: "jshint-loader",
        // more options in the optional jshint object
        options: {  // ⬅ formally jshint property
          camelcase: true,
          emitErrors: false,
          failOnHint: false
        }
      }]
    }]
  },
};
于 2017-07-24T07:32:28.640 回答
-1

唯一对我有用的是手动更改 jshint-loader 的文件。

  1. 转到 [您的项目路径]/node_modules/jshint-loader/index.js。
  2. 查找函数“jsHint”(第 61 行),然后转到第 63 行。
  3. 将“if(this.options.jshint)”更改为“if(options.jshint)”。
  4. 更改后,函数将如下所示:

    功能 jsHint(输入,选项){
        // 复制选项到自己的对象
        如果(选项.jshint){
            for(this.options.jshint 中的变量名称){
                选项[名称] = this.options.jshint[名称];
            }
        }
        //函数继续...
    }
    
    
于 2019-01-21T21:46:37.207 回答