javascript的严格模式是什么_它如何影响代码执行?

严格模式禁止未声明变量赋值、删除不可配置属性、重复函数参数、八进制字面量和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";} 是无效的。

严格模式对 thiseval 的影响

它改变了几个关键特性的默认行为:

  • 全局作用域中,函数内未绑定的 this 不再指向 window(浏览器)或 global(Node.js),而是 undefined,避免意外污染全局对象
  • eval 不再能创建变量或函数到外层作用域,其内部声明仅限于 eval 自身作用域
  • arguments 对象不再与形参自动同步(修改 arguments[0] 不再影响对应参数值)

是否推荐在新项目中使用?

现代 JavaScript(ES6+)已将很多严格模式规则融入语言本身,例如箭头函数、let/const、模块默认就是严格模式。对于仍使用 var 和传统函数的代码,显式开启严格模式仍是良好实践。它不是“过时特性”,而是提升代码健壮性的低成本手段。