JavaScript严格模式是ECMAScript 5引入的运行模式,通过"use strict";启用,限制隐式全局变量、静默失败操作、不安全语法,并使this在非方法调用时为undefined,提升代码健壮性与安全性。

JavaScript严格模式(Strict Mode)是ECMAScript 5引入的一种运行模式,通过在脚本或函数顶部添加"use strict";指令启用。它让JavaScript引擎以更严格、更安全的方式解析和执行代码,主动限制一些容易出错或不合理的语法和行为。
防止意外创建全局变量
非严格模式下,给未声明的变量赋值会自动创建全局变量,极易引发命名冲突和难以追踪的bug。
严格模式下,这种操作会直接抛出ReferenceError错误,强制开发者显式声明变量。
- 非严格:
counter = 10;→ 静默创建window.counter(浏览器环境) - 严格:
counter = 10;→ 报错Uncaught ReferenceError: counter is not defined
禁止静默失败的操作
很多在非严格模式中“看似成功”但实际无效的行为,在严格模式下会明确报错,提升可调试性。
立即学习“Java免费学习笔记(深入)”;
- 给只读属性赋值(如
Object.defineProperty(obj, 'x', { writable: false })后修改obj.x)→ 抛出TypeError - 删除不可配置属性(
delete obj.prop)→ 抛出TypeError(非严格模式返回false) - 重复定义对象属性(
{a: 1, a: 2})→ 语法错误(ES5严格模式下不允许)
限制不安全或易混淆的语法
严格模式禁用了一些历史遗留但存在风险的语言特性。
-
with语句被完全禁止(因其动态作用域导致性能差且难以优化) - 函数参数名不能重复(
function f(a, a) {...}→ 语法错误) -
arguments.callee和arguments.caller被禁用(影响优化且易造成内存泄漏) - 八进制字面量(如
010)被禁止(避免与十进制混淆;应使用0o10)
增强安全与执行一致性
严格模式让this在非方法调用场景下保持为undefined(而非自动绑定到全局对象),避免意外污染全局作用域。
例如:(function(){ console.log(this); })();
- 非严格:输出
window(浏览器)或global(Node.js) - 严格:输出
undefined
这对编写可复用、可预测的函数非常关键,尤其在事件回调或定时器中。
严格模式不是新语言,而是对原有JS的“加固层”。它不改变语法核心,但显著提升了代码健壮性、可维护性和执行安全性。现代开发中,建议默认启用——无论是模块化脚本还是函数级作用域,都能从中受益。










