我包括以下声明:
"use strict";
在我的大多数 Javascript 文件的开头。
JSLint 以前从未警告过这一点。但现在是,说:
使用“use strict”的函数形式。
有谁知道“函数形式”是什么?
包含 'use strict';
作为包装函数中的第一条语句,因此它只影响该函数。这可以防止在连接不严格的脚本时出现问题。
请参阅 Douglas Crockford 的最新博文 Strict Mode Is Coming To Town。
该帖子的示例:
(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 source code 中的地图(详细信息在 docs 中)。
更新 2: JSHint 支持 node:boolean
选项。请参阅.jshintrc
at github。
/* jshint node: true */
如果你正在为 NodeJS 编写模块,它们已经被封装了。通过在文件顶部包含以下内容来告诉 JSLint 您已经获得了节点:
/*jslint node: true */
/*jshint strict:false */
"node": true
添加到 .jshintrc
我建议改用 jshint。
它允许通过 /*jshint globalstrict: true*/
抑制此警告。
如果你正在编写一个库,我只建议在你的代码被封装到模块中时使用 global strict,就像 nodejs 的情况一样。
否则,您将强制使用您的库的每个人进入严格模式。
strict: 'global'
,看看 jshint.com/docs/options/#globalstrict
在 Cross Platform JavaScript 博文之后,我开始创建 Node.js/browserify 应用程序。我遇到了这个问题,因为我全新的 Gruntfile 没有通过 jshint。
幸运的是,我在 Leanpub book on Grunt 中找到了答案:
如果我们现在尝试,我们将扫描我们的 Gruntfile... 并得到一些错误: $ grunt jshint Running "jshint:all" (jshint) task Linting Gruntfile.js...ERROR [L1:C1] W097: Use the function form of “使用严格”。 '使用严格'; Linting Gruntfile.js ...错误 [L3:C1] W117: 'module' 未定义。 module.exports = function (grunt) { 警告:任务“jshint:all”失败。使用 --force 继续。这两个错误都是因为 Gruntfile 是一个 Node 程序,并且默认情况下 JSHint 不识别或不允许使用 module 和 use strict 的字符串版本。我们可以设置一个 JSHint 规则来接受我们的 Node 程序。让我们编辑我们的 jshint 任务配置并添加一个选项键: jshint: { options: { node: true }, }
将 node: true
添加到 jshint options
,将 jshint 置于“节点模式”,为我消除了这两个错误。
在项目的根目录中添加一个文件 .jslintrc(或 .jshintrc,如果是 jshint),其内容如下:
{
"node": true
}
字符串形式本身并没有错。
与其避免使用“全局”严格形式来担心连接非严格 javascript,不如将该死的非严格 javascript 修复为严格。
process.on('warning', function(e) {
'use strict';
console.warn(e.stack);
});
process.on('uncaughtException', function(e) {
'use strict';
console.warn(e.stack);
});
将此行添加到文件的起点
我想每个人都错过了这个问题的“突然”部分。很可能,您的 .jshintrc 有语法错误,因此它不包括“浏览器”行。通过 json 验证器运行它以查看错误在哪里。
就是这么简单:如果您想对所有代码都严格要求,请在 JavaScript 的开头添加 "use strict";
。
但是,如果您只想对某些代码严格,请使用函数形式。无论如何,我建议您在 JavaScript 的开头使用它,因为这将帮助您成为更好的编码器。
"use strict";
放在我的 JS 文件顶部时,我确实得到了这个错误,所以这可能并不完全正确。
"use strict";
的“全局”形式,它只是放在代码的顶部。仅当包装在函数中时才允许 "use strict;"
。 (不过,JS_Hint_ 允许您使用全局表单——有关所需设置,请参见上面的答案)。
-1
/*jshint strict:false */
,以更清楚地说明您在做什么(除非我不知道您的数字代码有什么特别的好处)"use strict";
。