严格模式通过”use strict”启用,可全局或局部应用。它禁止意外创建全局变量、删除变量或函数、重复参数名、八进制字面量,限制保留字使用,并使函数中this为undefined而非全局对象,有助于发现错误、提升性能和代码规范性,现代模块系统默认采用。

JavaScript 严格模式(Strict Mode)是一种在 ECMAScript 5 引入的语法变体,它让代码在更严格的条件下执行,有助于捕获常见的编码错误、防止某些“危险”的行为,并为未来的 JavaScript 版本铺平道路。启用严格模式后,JavaScript 引擎会应用更严格的语法规则和错误检查。
如何启用严格模式
严格模式可以通过在脚本或函数的顶部添加 “use strict”; 字面量字符串来启用。
1. 全局启用(整个脚本):
在脚本的最开始写上 “use strict”;,这样整个脚本都会运行在严格模式下。
"use strict";function myFunction() { x = 10; // 报错:x 未声明}myFunction();
2. 局部启用(仅函数内):
将 “use strict”; 放在函数体的第一行,只对该函数启用严格模式。
立即学习“Java免费学习笔记(深入)”;
function strictFunc() { "use strict"; y = 20; // 报错:y 未声明}function normalFunc() { z = 30; // 正常(非严格模式)}
严格模式带来的主要变化
启用严格模式后,以下行为会被限制或抛出错误:
1. 禁止意外创建全局变量
在非严格模式中,给未声明的变量赋值会自动创建一个全局变量。严格模式下会抛出错误。
"use strict";mistypedVariable = 17; // ReferenceError: mistypedVariable is not defined
2. 禁止删除变量、函数和函数参数
不能使用 delete 删除变量名、函数名或参数。
"use strict";var foo = 1;delete foo; // SyntaxError
3. 函数参数名不能重复
严格模式下,函数定义时参数名重复会报错。
"use strict";function sum(a, a, c) { // SyntaxError return a + a + c;}
4. 禁止八进制数字字面量
以 0 开头的数字被视为非法八进制(如 010),避免歧义。
"use strict";var n = 010; // SyntaxError
5. this 不再指向全局对象
在普通函数中,this 会是 undefined 而不是 window(浏览器中),减少因 this 指向错误导致的 bug。
"use strict";function f() { return this;}console.log(f()); // undefined(非严格模式下是 window)
6. 保留字限制增强
一些未来可能使用的关键词(如 implements, interface, let, package 等)在严格模式中不能用作变量名。
为什么推荐使用严格模式
使用严格模式能让代码更安全、更清晰:
帮助发现静默错误(如拼写错误导致的全局变量) 提升性能(引擎可进行更多优化) 为 ES6+ 模块化等新特性做准备(模块默认处于严格模式) 促使开发者写出更规范的代码
基本上就这些。虽然现代开发多使用构建工具和模块系统(如 ES Modules、CommonJS),它们默认启用严格模式,但了解其原理仍对调试和兼容性处理很有帮助。不复杂但容易忽略。
以上就是JavaScript严格模式使用_javascript语法规范的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1540422.html
微信扫一扫
支付宝扫一扫