严格模式通过启用限制性规则提升代码质量与可维护性,需在脚本顶部或函数首行添加"use strict";激活,能捕获未声明赋值、重复参数等错误,并使this指向更明确。

JavaScript中的严格模式(Strict Mode)是一种让代码在更严格的条件下运行的机制,它通过启用一组限制性规则,帮助开发者提前发现潜在问题、避免不安全操作,并提升代码质量与可维护性。
严格模式如何激活
严格模式需要显式启用,有两种方式:
- 在脚本最顶部添加 "use strict";(注意:必须是第一行可执行语句,前面不能有变量声明或注释)
- 在函数内部第一行写 "use strict";,则只对该函数生效
常见错误被严格模式捕获
很多在非严格模式下“静默失败”或产生意外行为的问题,在严格模式中会直接抛出错误,比如:
-
未声明就赋值变量:如
name = "Alice"会报ReferenceError,强制要求用let、const或var -
重复参数名:函数定义
function test(a, a) { }在严格模式下报SyntaxError -
禁止删除不可配置属性:如
delete Object.prototype.toString会触发TypeError -
this 指向更明确:全局函数中
this不再默认指向window(浏览器)或global(Node.js),而是undefined,避免隐式绑定错误
对代码质量和协作的实质帮助
严格模式不是为了增加限制而存在,而是把一些容易被忽略的“灰色地带”变成明确的错误信号:
立即学习“Java免费学习笔记(深入)”;
- 减少因拼写错误导致的静默失败(如把
user.name写成user.nam,虽然仍不会报错,但配合工具链更容易暴露) - 让代码行为更可预测,尤其在模块化开发和团队协作中,降低理解成本
- 为未来 JavaScript 特性预留兼容空间,许多新语法(如箭头函数、模块)默认处于严格模式环境
需要注意的细节
严格模式不是万能的,也不改变所有行为逻辑:
- 它不会检查变量是否未使用、类型是否匹配,这些需靠 TypeScript 或 ESLint 等工具补充
- 无法自动修复 bug,只是让问题更早暴露
- 旧项目迁移时可能触发大量报错,建议逐步在新模块或函数中启用










