严格模式通过"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
禁止使用某些不安全或过时的语法
严格模式禁用了一些容易引发错误或已被废弃的特性:
立即学习“Java免费学习笔记(深入)”;
- 禁止八进制字面量(如
010),必须写成0o10或0x10 - 禁止删除不可配置属性:
delete Object.prototype会报TypeError - 函数参数名不能重复:
function fn(a, a) { }→SyntaxError - 禁止对
eval和arguments赋值或用作变量名
this 的绑定更明确
在非严格模式中,全局上下文中的 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";。但普通脚本仍需显式开启,尤其在维护旧项目时值得考虑逐步引入。











