严格模式将静默失败转为显式错误:未声明变量赋值报ReferenceError、重复参数/属性名抛SyntaxError、只读属性赋值报错、非对象中this为undefined;禁用with、八进制字面量、arguments.callee及delete变量。

JavaScript 的严格模式(Strict Mode)是一种让代码在更严格的条件下运行的机制,它通过启用一组限制性更强的语法规则和错误检查,帮助开发者写出更安全、更清晰、更易维护的代码。
严格模式能捕获哪些常见错误?
它把一些原本“静默失败”的问题变成明确的运行时错误,比如:
- 给未声明的变量赋值会直接报
ReferenceError,而不是意外创建全局变量 - 重复定义函数参数(如
function foo(a, a) {})会抛出SyntaxError - 对象中重复的属性名(如
{a: 1, a: 2})在严格模式下是语法错误(ES5 中) - 对只读属性或不可扩展对象赋值会立即报错,而不是忽略操作
-
this在非对象上下文中(如普通函数调用)不再指向全局对象,而是undefined,避免隐式绑定陷阱
如何启用严格模式?
有两种方式,推荐在每个脚本或函数顶部显式开启:
- 整个脚本启用:在文件最开头写
"use strict";(注意是字符串字面量,不是指令) - 单个函数启用:在函数体第一行写
"use strict";,只对该函数生效
注意:不能在块级作用域(如 if 或 {} 内)中启用;且一旦启用,无法在内部关闭。
立即学习“Java免费学习笔记(深入)”;
它还限制了哪些容易被忽视的危险行为?
严格模式禁用了部分不安全或已废弃的特性:
- 禁止使用
with语句(因为它影响作用域查找,难以优化和调试) - 禁用八进制字面量(如
010),除非写成0o10形式 -
arguments.callee和arguments.caller不可用,促使使用命名函数或 rest 参数 - 删除变量(
delete myVar)或不可配置属性会报错,防止误删
基本上就这些。严格模式不会改变 JavaScript 的核心逻辑,但它像一位细心的协作者,在你写出模糊、易错或过时写法时及时提醒——不是为了刁难,而是帮你避开那些上线后才暴露的坑。










