JavaScript模块和类默认启用严格模式,禁止删除不可配置属性或参数、函数参数名重复、八进制字面量使用0前缀,this不绑定全局对象,arguments与参数不再联动,避免静默错误并提升代码安全。

JavaScript 的严格模式确实在模块(ES6 modules)和类(class)中默认启用,不需要手动添加 "use strict"。除了常见的不能使用未声明变量等规则外,还有一些容易被忽略的限制,开发者在实际编码中稍不注意就可能踩坑。
1. 禁止删除不可配置的属性和函数参数
在严格模式下,尝试删除不可配置的对象属性或函数的参数会直接抛出错误,而不是静默失败。
例如:
function foo(x) {delete x; // 报错:Strict mode forbids deleting variable
}
const obj = {};
Object.defineProperty(obj, 'prop', { configurable: false });
delete obj.prop; // 报错
而在非严格模式中,这些操作只会返回 false,不会中断执行。
立即学习“Java免费学习笔记(深入)”;
2. 函数参数名必须唯一
严格模式禁止函数有重复的参数名,这在处理回调或兼容旧代码时容易被忽视。
function bar(a, a, c) { // 报错:Duplicate parameter name not allowedreturn a + c;
}
非严格模式下虽然允许,但行为诡异——后面的参数会覆盖前面的值,且 arguments 的映射关系混乱。
3. this 不再自动绑定到全局对象
在普通函数中,如果调用时没有指定上下文,this 在严格模式下为 undefined,而非指向 window(浏览器)或 global(Node.js)。
console.log(this); // 严格模式下是 undefined
}
baz();
这对依赖 this 判断运行环境的代码会造成影响,尤其在工具函数中容易出错。
4. 禁止八进制字面量
以 0 开头的数字被视为非法八进制,会引发语法错误。
let num = 010; // 报错:Invalid numberlet oct = 0o10; // 正确:必须使用 0o 前缀
虽然现代开发中少见,但在解析用户输入或迁移老代码时可能触发。
5. arguments 不再追踪参数变化
在非严格模式中,修改命名参数会影响 arguments 对象的对应索引。严格模式切断了这种双向绑定。
a = 42;
console.log(arguments[0]); // 严格模式下仍输出原值,不会变
}
这使得参数和 arguments 更独立,但也意味着不能再依赖这种联动做元编程。
基本上就这些。虽然模块和类默认开启严格模式让很多问题提前暴露,但理解这些隐藏限制,能避免一些看似合理却报错的行为。










