JavaScript Strict Mode
"use strict";
定义了 JavaScript 代码应在“严格模式”下执行。
"use strict" 指令
"use strict"
指令是 ECMAScript 版本 5 中的新特性。
它不是一个语句,而是一个字面量表达式,会被早期版本的 JavaScript 忽略。
"use strict"
的目的是表明代码应在“严格模式”下执行。
在严格模式下,您不能使用未声明的变量,例如。
除了 Internet Explorer 9 及更早版本,所有现代浏览器都支持“use strict”。
指令 | |||||
---|---|---|---|---|---|
"use strict" | 13.0 | 10.0 | 4.0 | 6.0 | 12.1 |
表格中的数字表示完全支持该指令的第一个浏览器版本。
您可以在所有程序中使用严格模式。它可以帮助您编写更清晰的代码,例如防止您使用未声明的变量。
"use strict"
只是一个字符串,所以即使 IE 9 不理解它,也不会抛出错误。
声明严格模式
严格模式通过在脚本或函数的开头添加 "use strict"; 来声明。
在脚本开头声明,它具有全局作用域(脚本中的所有代码都将在严格模式下执行)
在函数内声明,它具有局部作用域(只有函数内的代码在严格模式下执行)
x = 3.14; // 这不会导致错误。
myFunction();
function myFunction() {
"use strict";
y = 3.14; // 这将导致错误
}
自己动手试一试 »
“use strict”; 语法
声明严格模式的语法旨在与早期版本的 JavaScript 兼容。
在 JavaScript 程序中编译数字字面量 (4 + 5;) 或字符串字面量 ("John Doe";) 没有副作用。它只是编译成一个不存在的变量并失效。
因此,"use strict";
只对“理解”其含义的新编译器有意义。
为什么使用严格模式?
严格模式有助于编写更“安全”的 JavaScript。
严格模式将之前被接受的“坏语法”变成真正的错误。
例如,在普通 JavaScript 中,拼错变量名会创建一个新的全局变量。在严格模式下,这会抛出错误,使得意外创建全局变量成为不可能。
在普通 JavaScript 中,开发人员不会收到任何错误反馈来为不可写属性赋值。
在严格模式下,任何对不可写属性、只读属性、不存在的属性、不存在的变量或不存在的对象进行的赋值都将抛出错误。
在严格模式下不允许
使用未声明的变量是不允许的
"use strict";
x = 3.14; // 这将导致错误
对象也是变量。
使用未声明的对象是不允许的
"use strict";
x = {p1:10, p2:20}; // 这将导致错误
删除变量(或对象)是不允许的。
"use strict";
let x = 3.14;
delete x; // 这将导致错误
删除函数是不允许的。
"use strict";
function x(p1, p2) {};
delete x; // 这将导致错误
重复参数名是不允许的
"use strict";
function x(p1, p1) {}; // 这将导致错误
八进制数字字面量是不允许的
"use strict";
let x = 010; // 这将导致错误
八进制转义字符是不允许的
"use strict";
let x = "\010"; // 这将导致错误
写入只读属性是不允许的
"use strict";
const obj = {};
Object.defineProperty(obj, "x", {value:0, writable:false});
obj.x = 3.14; // 这将导致错误
写入只读属性是不允许的
"use strict";
const obj = {get x() {return 0} };
obj.x = 3.14; // 这将导致错误
删除不可删除的属性是不允许的
"use strict";
delete Object.prototype; // 这将导致错误
单词 eval
不能用作变量
"use strict";
let eval = 3.14; // 这将导致错误
单词 arguments
不能用作变量
"use strict";
let arguments = 3.14; // 这将导致错误
with
语句是不允许的
"use strict";
with (Math){x = cos(2)}; // 这将导致错误
出于安全原因,不允许 eval()
从其被调用的作用域创建变量。
函数中的 this
关键字在严格模式下的行为不同。
this
关键字引用调用函数的对象。
如果未指定对象,严格模式下的函数将返回 undefined
,而普通模式下的函数将返回全局对象 (window)
"use strict";
function myFunction() {
alert(this); // 将会 alert "undefined"
}
myFunction();
面向未来!
未来 JavaScript 版本保留的关键字不能在严格模式下用作变量名。
这些是
- implements
- interface
- let
- package
- private
- protected
- 公共
- static
- yield
"use strict";
let public = 1500; // 这将导致错误
注意!
"use strict" 指令只能在脚本或函数的开头被识别。