严格模式通过"use strict"启用,限制不安全语法、强制显式变量声明、明确this绑定、增强错误提示,提升代码健壮性与可维护性。
JavaScript 严格模式(Strict Mode)是一种让代码在更严格条件下运行的可选模式,它通过限制一些不安全、易出错或不推荐的语法和行为,帮助开发者写出更健壮、更可维护的代码。
在脚本或函数顶部添加 "use strict"; 字符串字面量即可启用。注意:必须是纯字符串,不能带变量或表达式,且必须出现在作用域最开始(否则无效)。
"use strict";
function foo() { ... }
function bar() {
"use strict";
...
}在严格模式下,未用 var、let 或 const 声明就直接赋值的变量会抛出 ReferenceError,而不是自动创建全局变量。
name = "Alice"; → 静默创建全局 window.name
name = "Alice"; → 报错:ReferenceError: name is not defined
严格模式禁用了一些容易引发错误或已被废弃的特性:
010),必须写成 0o10 或 0x10
delete Object.prototype 会报 TypeError
function fn(a, a) { } → Synta
xError
eval 和 arguments 赋值或用作变量名在非严格模式中,全局上下文中的 this 指向全局对象(如 window);而严格模式下,函数独立调用时 this 为 undefined,避免意外修改全局对象。
function foo() { return this; }
foo(); // window(浏览器中)foo(); // undefined,强制你明确绑定 this(如用 call、bind 或箭头函数)严格模式让部分静默失败变为显式报错,便于早期发现问题:
NaN = 5)抛出 TypeError
Object.preventExtensions(obj); obj.x = 1;)报错implements、interface)在严格模式中不能用作标识符现代 JavaScript(ES6+)已默认在模块(.mjs 或 type="module" 的 script)中启用严格模式,无需手动添加 "use strict";。但普通脚本仍需显式开启,尤其在维护旧项目时值得考虑逐步引入。