JavaScript的严格模式通过在脚本或函数顶部添加use strict指令开启,它会让JavaScript引擎以更严格的方式解析和执行代码,消除一些静默错误,优化性能。但其中不少限制比较隐蔽,容易被开发者忽略。

容易被忽略的严格模式限制
1. 禁止未声明直接赋值变量
非严格模式下,给未声明的变量赋值会自动创建全局变量,而严格模式下会直接抛出错误。
"use strict"; // 直接给未声明的变量赋值,会抛出ReferenceError a = 10; // Uncaught ReferenceError: a is not defined
2. 禁止函数参数重名
非严格模式允许函数参数有重复的名称,后面的参数会覆盖前面的,严格模式下这种写法会直接报错。
"use strict";
// 函数参数重名,严格模式下语法错误
function test(a, a) { // Uncaught SyntaxError: Duplicate parameter name not allowed in strict mode
return a;
}
3. 禁止删除不可删除的属性
尝试删除不可配置的属性时,非严格模式会静默失败,严格模式会抛出错误。
"use strict"; // 尝试删除不可删除的属性,抛出TypeError delete Object.prototype; // Uncaught TypeError: Cannot delete property 'prototype' of function Object()
4. 禁止八进制数字字面量
以0开头的八进制字面量在严格模式下不被允许,会直接抛出语法错误。
"use strict"; // 八进制字面量,严格模式下语法错误 let num = 0123; // Uncaught SyntaxError: Octal literals are not allowed in strict mode
5. 禁止with语句
with语句会改变作用域链,严格模式下完全禁止使用,否则会抛出语法错误。
"use strict";
let obj = { a: 1 };
// 使用with语句,严格模式下语法错误
with(obj) { // Uncaught SyntaxError: Strict mode code may not include a with statement
console.log(a);
}
6. eval作用域隔离
严格模式下,eval内部声明的变量不会泄露到外部作用域,和非严格模式的行为不同。
"use strict";
eval("var x = 2;");
console.log(x); // Uncaught ReferenceError: x is not defined
7. 函数内的this不再默认指向全局对象
非严格模式下,普通函数调用时this默认指向全局对象(浏览器中是window),严格模式下this会是undefined。
"use strict";
function showThis() {
console.log(this);
}
showThis(); // 输出 undefined,非严格模式会输出 window
8. 禁止在函数内部遍历caller和callee
arguments对象的caller和callee属性在严格模式下被禁用,访问会抛出错误。
"use strict";
function test() {
// 访问arguments.callee,抛出TypeError
console.log(arguments.callee); // Uncaught TypeError: 'caller', 'callee', and 'arguments' properties may not be accessed on strict mode functions
}
test();
总结
严格模式的这些限制大多是为了规避JavaScript设计中的历史遗留问题,让代码更规范、更不容易出错。开发者在开启严格模式时,需要留意上述容易被忽略的规则,提前调整代码写法,避免运行时出现异常。日常开发中建议默认开启严格模式,有助于提升代码质量和可维护性。
JavaScriptStrict_Mode严格模式变量声明函数参数修改时间:2026-06-29 16:54:16