当前位置:首页 > 文章列表 > 文章 > 前端 > 严格模式是什么?启用好处全解析

严格模式是什么?启用好处全解析

2026-04-16 08:41:34 0浏览 收藏
JavaScript严格模式并非新增语法,而是一个让引擎将原本静默失败、自动修复或模糊绑定的行为(如未声明变量赋值、this 指向混乱、arguments 与形参耦合等)立即转为明确错误的“安全开关”;它必须通过精确位置的字符串字面量 `"use strict"` 手动启用——脚本顶部或函数体首行,且在 CommonJS 和传统 script 中不可省略,而 ES 模块已默认强制启用;启用后虽大幅提升代码可预测性与调试效率,却也悄然改变 this 绑定、arguments 行为及 eval 作用域等关键运行逻辑,使老旧代码在迁移时可能意外崩溃,因此真正关键的不是“是否启用”,而是“是否正确启用”以及“是否意识到那些被打破的隐式假设”。

什么是javascript严格模式_启用严格模式有什么好处【教程】

严格模式不是“新功能”,而是让 JS 引擎立刻报错的开关

它不新增语法,只把原本静默失败、自动修复、模糊绑定的行为变成明确错误。比如 name = "Alice" 在非严格模式下会悄悄挂到 window.name 上,而严格模式下直接抛出 ReferenceError: name is not defined——你立刻就知道漏写了 letconst

怎么启用?位置错了就等于没开

必须用字符串字面量 "use strict",且只能出现在两个地方:

  • 整个脚本最顶部(前面不能有任何 JS 语句,注释和空行可以)
  • 函数体第一行(包括 IIFE 内部)

下面这些写法都无效:

"use strict";
console.log("ok"); // ✅ 全局启用

function foo() {
  console.log(1);
  "use strict"; // ❌ 中间写,不生效
}

if (true) {
  "use strict"; // ❌ 包在块里,引擎直接忽略
}

ES 模块默认严格,但 CommonJS 和内联脚本仍要手动加

如果你用的是 import/export.mjs 文件,或