繁体   English   中英

JSLint 突然报告:使用“use strict”的函数形式

[英]JSLint is suddenly reporting: Use the function form of “use strict”

我包括以下声明:

"use strict";

在我的大多数 Javascript 文件的开头。

JSLint 以前从未警告过这一点。 但现在是,说:

使用“use strict”的函数形式。

有谁知道“函数形式”是什么?

包括'use strict'; 作为包装函数中的第一条语句,因此它只影响该函数。 这可以防止在连接不严格的脚本时出现问题。

请参阅道格拉斯·克罗克福德 (Douglas Crockford) 的最新博客文章严格模式即将到来

该帖子中的示例:

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

(function () {
   // but this function is sloppy...
}());

更新:如果您不想立即包装(例如它是一个节点模块),那么您可以禁用警告。

对于JSLint (每个Zhami ):

/*jslint node: true */

对于JSHint

/*jshint strict:false */

或(根据Laith Shadeed

/* jshint -W097 */

要禁用来自 JSHint 的任何任意警告,请检查JSHint 源代码中的映射(文档中的详细信息)。

更新 2: JSHint支持node:boolean选项。 请参阅github 上的.jshintrc

/* jshint node: true */

如果您正在为 NodeJS 编写模块,那么它们已经被封装了。 通过在文件的顶部包含来告诉 JSLint 你有节点:

/*jslint node: true */

我建议改用jshint

它允许通过/*jshint globalstrict: true*/抑制此警告。

如果您正在编写一个库,我只建议在您的代码像 nodejs 一样封装到模块中时使用 global strict。

否则你会强制每个使用你的库的人进入严格模式。

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

幸运的是,我在关于 GruntLeanpub 书中找到了答案:

如果我们现在尝试,我们将扫描我们的 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 不识别或不允许使用moduleuse strict的字符串版本。 我们可以设置一个 JSHint 规则来接受我们的 Node 程序。 让我们编辑我们的 jshint 任务配置并添加一个选项键:

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

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

在项目的根目录添加一个文件 .jslintrc(或 .jshintrc,如果是 jshint),内容如下:

{
    "node": true
}

字符串形式没有什么天生的错误。

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

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

process.on('warning', function(e) {
    'use strict';
    console.warn(e.stack);
});
process.on('uncaughtException', function(e) {
    'use strict';
    console.warn(e.stack);
});

将此行添加到文件的起点

就是这么简单:如果你想对你的所有代码都严格,加上"use strict"; 在您的 JavaScript 开始时。

但是,如果您只想对您的某些代码进行严格处理,请使用函数形式。 无论如何,我建议您在 JavaScript 开始时使用它,因为这将帮助您成为更好的编码员。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM