JSLint 突然报告:使用 “使用严格” 功能形式

"use strict";

答案

(function () {
   'use strict';
   // this function is strict...
}());

(function () {
   // but this function is sloppy...
}());
/*jslint node: true */
/*jshint strict:false */
/* jshint -W097 */
/* jshint node: true */
/*jslint node: true */

我建议改用jshint

它允许通过/*jshint globalstrict: true*/禁止显示此警告。

如果您正在编写库,则仅建议您将代码封装到模块中(就像使用 nodejs 一样),建议使用全局严格。

否则,您将迫使所有正在使用您的库的用户进入严格模式。

Cross Platform JavaScript博客文章之后,我开始创建 Node.js / browserify 应用程序。我遇到了这个问题,因为我的全新 Gruntfile 没有通过 jshint。

幸运的是,我在Leanpub 上有关 Grunt 的书中找到了答案:

如果现在尝试,我们将扫描我们的 Gruntfile… 并得到一些错误:

$ grunt jshint

Running "jshint:all" (jshint) task
Linting Gruntfile.js...ERROR
[L1:C1] W097: Use the function form of "use strict".
'use strict';
Linting Gruntfile.js...ERROR
[L3:C1] W117: 'module' is not defined.
module.exports = function (grunt) {

Warning: Task "jshint:all" failed. Use --force to continue.

这两个错误都是因为 Gruntfile 是 Node 程序,并且默认情况下 JSHint 不识别或不允许使用module以及use strict的字符串版本。我们可以设置一个 JSHint 规则来接受我们的 Node 程序。让我们编辑 jshint 任务配置并添加一个选项键:

jshint: {
  options: {
    node: true
  },
}

为 jshint options添加node: true ,将 jshint 设置为 “节点模式”,为我消除了这两个错误。

{
    "node": true
}

字符串形式天生没有错。

与其避免担心连接非严格 javascript 的 “全局” 严格形式,不如将可恶的非严格 javascript 修复为严格可能更好。

我认为每个人都错过了这个问题的 “突然” 部分。您的. jshintrc 最有可能出现语法错误,因此不包括 “浏览器” 行。通过 json 验证程序运行它以查看错误在哪里。

这很简单:如果您想对所有代码都严格,则添加"use strict";在 JavaScript 的开头。

但是,如果您只想严格遵守某些代码,请使用函数形式。无论如何,我建议您在 JavaScript 的开头使用它,因为这将帮助您成为更好的编码器。