登录
首页 >  文章 >  前端

JavaScript严格模式是什么?开启后有什么变化?

时间:2026-01-05 21:42:45 454浏览 收藏

“纵有疾风来,人生不言弃”,这句话送给正在学习文章的朋友们,也希望在阅读本文《JavaScript严格模式是什么?开启后有何变化?》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新文章相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

严格模式通过"use strict"启用,限制不安全语法、强制显式变量声明、明确this绑定、增强错误提示,提升代码健壮性与可维护性。

什么是javascript的严格模式?_开启严格模式会对javascript代码产生哪些影响?

JavaScript 严格模式(Strict Mode)是一种让代码在更严格条件下运行的可选模式,它通过限制一些不安全、易出错或不推荐的语法和行为,帮助开发者写出更健壮、更可维护的代码。

如何开启严格模式

在脚本或函数顶部添加 "use strict"; 字符串字面量即可启用。注意:必须是纯字符串,不能带变量或表达式,且必须出现在作用域最开始(否则无效)。

  • 全局开启(整个脚本生效):
    "use strict";
    function foo() { ... }
  • 函数级开启(仅对该函数及其内部嵌套函数生效):
    function bar() {
      "use strict";
      ...
    }

变量声明必须显式化

在严格模式下,未用 varletconst 声明就直接赋值的变量会抛出 ReferenceError,而不是自动创建全局变量。

  • 非严格模式:name = "Alice"; → 静默创建全局 window.name
  • 严格模式:name = "Alice"; → 报错:ReferenceError: name is not defined

禁止使用某些不安全或过时的语法

严格模式禁用了一些容易引发错误或已被废弃的特性:

  • 禁止八进制字面量(如 010),必须写成 0o100x10
  • 禁止删除不可配置属性:delete Object.prototype 会报 TypeError
  • 函数参数名不能重复:function fn(a, a) { }SyntaxError
  • 禁止对 evalarguments 赋值或用作变量名

this 的绑定更明确

在非严格模式中,全局上下文中的 this 指向全局对象(如 window);而严格模式下,函数独立调用时 thisundefined,避免意外修改全局对象。

  • 非严格:function foo() { return this; }
    foo(); // window(浏览器中)
  • 严格:foo(); // undefined,强制你明确绑定 this(如用 callbind 或箭头函数)

增强错误提示与调试能力

严格模式让部分静默失败变为显式报错,便于早期发现问题:

  • 对只读属性赋值(如 NaN = 5)抛出 TypeError
  • 对不可扩展对象添加新属性(Object.preventExtensions(obj); obj.x = 1;)报错
  • 某些未来保留字(如 implementsinterface)在严格模式中不能用作标识符

现代 JavaScript(ES6+)已默认在模块(.mjstype="module" 的 script)中启用严格模式,无需手动添加 "use strict";。但普通脚本仍需显式开启,尤其在维护旧项目时值得考虑逐步引入。

终于介绍完啦!小伙伴们,这篇关于《JavaScript严格模式是什么?开启后有什么变化?》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>