严格模式通过"use strict"提升代码安全与质量:1. 强制显式声明变量,避免全局污染;2. 禁止删除变量或函数;3. 要求函数参数唯一;4. 禁用八进制数字字面量;5. 函数中this为undefined而非全局对象;6. 禁用with语句;7. 隔离eval作用域。

JavaScript的严格模式(Strict Mode)是一种在ECMAScript 5中引入的机制,通过在脚本或函数顶部添加 "use strict"; 来启用。它能帮助开发者避免常见的编码错误,提升代码的安全性和可维护性。在严格模式下,JavaScript会更严格地检查语法和运行时行为,禁用一些不安全或模糊的特性。
在非严格模式下,如果忘记使用 var、let 或 const 声明变量,JavaScript会自动创建一个全局变量。这容易导致命名冲突和难以追踪的bug。
严格模式下,未声明就赋值的行为会抛出错误:
"use strict"; username = "Alice"; // 抛出 ReferenceError
因此,所有变量必须显式声明,有助于保持作用域清晰。
立即进入“豆包AI人工智官网入口”;
立即学习“豆包AI人工智能在线问答入口”;
严格模式禁止删除变量、函数或不可配置的对象属性,避免产生不可预期的结果。
"use strict";
var age = 30;
delete age; // 抛出 SyntaxError
function sayHello() {}
delete sayHello; // 抛出 SyntaxError
这一限制提高了代码的稳定性,防止误操作破坏程序结构。
在非严格模式下,函数可以拥有重名的参数名,后面的参数会覆盖前面的。这容易引发逻辑错误。
严格模式要求函数参数名必须唯一:
"use strict";
function greet(name, name) { // 抛出 SyntaxError
return "Hello " + name;
}
这个规则让参数定义更清晰,减少歧义。
以0开头的数字在非严格模式中可能被解析为八进制,如 010 被当作8。这种写法容易造成误解。
严格模式下,这类语法会被视为错误:
"use strict"; var num = 010; // 抛出 SyntaxError
若需使用八进制,应使用 0o 前缀(ES6标准):
var num = 0o10; // 正确,值为8
在非严格模式下,函数中的 this 在未绑定时默认指向全局对象(浏览器中是 window)。而在严格模式下,this 保持为 undefined。
function getThis() {
"use strict";
return this;
}
getThis(); // 返回 undefined,而非 window
这一变化有助于避免因this误用导致的安全问题,尤其是在事件处理或回调中。
with 语句会动态改变作用域链,使代码难以优化且容易出错。严格模式明确禁止使用它:
"use strict";
with (Math) { // 抛出 SyntaxError
x = cos(3);
}
移除 with 可提升代码可读性和执行效率。
在非严格模式下,eval() 可以访问并修改其外部变量,还可能在内部声明影响外层的变量。
严格模式下,eval() 拥有独立的作用域,不会污染外部环境:
"use strict";
eval("var secret = 42;");
console.log(typeof secret); // "undefined"
这增强了代码隔离性,降低潜在风险。
基本上就这些。启用严格模式虽小,却能显著提升代码质量。建议在所有现代JavaScript项目中主动使用 "use strict",尤其是在模块化开发之前。它不是万能防护,但却是通向更可靠编程的第一步。
以上就是JavaScript严格模式下的安全编程规范的详细内容,更多请关注php中文网其它相关文章!
编程怎么学习?编程怎么入门?编程在哪学?编程怎么学才快?不用担心,这里为大家提供了编程速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号