严格模式禁止未声明变量赋值、删除不可配置属性、重复函数参数、八进制字面量和with语句;启用方式为脚本或函数首行添加"use strict";使this在全局函数中为undefined,限制eval作用域,解除arguments与形参同步;新项目仍推荐使用。

JavaScript 的严格模式(Strict Mode)是一种让代码在更严格的条件下运行的模式,它通过启用一组限制性更强的语法规则和错误检查机制,帮助开发者写出更安全、更清晰、更易维护的代码。
严格模式会禁止哪些常见错误行为?
启用严格模式后,一些原本不会报错、但容易引发 bug 的操作会被直接拒绝执行:
- 给未声明的变量赋值会抛出 ReferenceError(而不是静默创建全局变量)
- 删除不可配置的属性(如
delete Object.prototype)会抛出 TypeError - 函数参数名重复(如
function foo(a, a) {})会触发 SyntaxError - 八进制字面量(如
010)被禁用,避免歧义 -
with语句被完全禁止,因为它会影响作用域查找效率和可预测性
如何启用严格模式?
有两种方式激活严格模式:
-
脚本级启用:在 JS 文件或
标签的最顶部添加"use strict";(注意必须是第一行有效语句,前面只能有注释) -
函数级启用:在函数体的第一行写
"use strict";,只对该函数及其内部嵌套函数生效
注意:不能在函数条件分支里动态启用,比如 if (true) {"use strict";} 是无效的。
立即学习“Java免费学习笔记(深入)”;
严格模式对 this 和 eval 的影响
它改变了几个关键特性的默认行为:
- 全局作用域中,函数内未绑定的
this不再指向window(浏览器)或global(Node.js),而是 undefined,避免意外污染全局对象 -
eval不再能创建变量或函数到外层作用域,其内部声明仅限于 eval 自身作用域 - arguments 对象不再与形参自动同步(修改
arguments[0]不再影响对应参数值)
是否推荐在新项目中使用?
现代 JavaScript(ES6+)已将很多严格模式规则融入语言本身,例如箭头函数、let/const、模块默认就是严格模式。对于仍使用 var 和传统函数的代码,显式开启严格模式仍是良好实践。它不是“过时特性”,而是提升代码健壮性的低成本手段。











