javascript严格模式如何启用_它限制了哪些不安全操作?

启用严格模式需在脚本或函数首行添加"use strict";:全局模式作用于整个脚本,函数模式仅限该函数;ES6模块默认启用。严格模式禁止隐式创建全局变量、删除不可配置属性、this指向全局对象等行为,提升代码健壮性。

在 JavaScript 中启用严格模式,只需在脚本或函数的最开头添加 "use strict";(字符串字面量),它就会激活该作用域下的严格检查。

如何启用严格模式

有两种启用方式,作用范围不同:

  • 全局严格模式:把 "use strict"; 放在脚本第一行(前面不能有其他语句,包括注释也不行),整个脚本都受限制;
  • 函数级严格模式:在函数体第一行写 "use strict";,只对该函数内部生效,不影响外部或其他函数。

注意:ES6 模块(import/export)默认就是严格模式,无需手动加。

禁止隐式创建全局变量

非严格模式下,给未声明的变量赋值会自动挂到 window(浏览器)或 global(Node.js)上;严格模式下这会直接报 ReferenceError

例如:

function foo() {
  "use strict";
  mistypedVar = 17; // 报错:Uncaught ReferenceError
}

禁止删除不可配置属性和变量

严格模式下,对普通变量、函数参数、函数名使用 delete 会抛出 SyntaxErrorTypeError

  • delete Object.prototype → 报错(非严格下静默失败);
  • delete x(x 是 var x = 1 声明的)→ 报错;
  • delete arguments → 报错;

限制 this 的绑定行为

非严格模式中,独立调用函数时 this 指向全局对象(如 window);严格模式下,this 保持为 undefined

这能避免意外修改全局对象,也使箭头函数、call/apply 的行为更可预测。

其他关键限制

  • 禁止八进制字面量:像 010 这种老式写法会报错(可用 0o10 替代);
  • 禁止重复参数名:函数定义 function foo(a, a) { } 在严格模式下是语法错误;
  • 禁止使用 with 语句:因作用域不明确且影响性能,直接禁用;
  • 增强 eval 隔离性:在严格模式中,eval 内部声明的变量不会泄露到外层作用域。

基本上就这些。严格模式不是让 JS 更“难写”,而是提前暴露常见错误、减少歧义、提升代码健壮性。现在新项目建议默认开启,尤其配合 ESLint 等工具效果更好。