前回の記事で、このキーワードが問題を示していると述べたときに、ストリクトモードについて言及し続けましたが、ここではストリクトモードとは何かについて説明します~~~
厳密モードとは何ですか?
JavaScript 厳密モード (厳密モード) は、コードが厳密な条件下で実行されることを指定します。
ステートメントではなくリテラル式である「use strict」ディレクティブ (JavaScript 1.8.5 (ECMAScript5) の新機能) を使用します。
厳密モードの目的は何ですか?
Javascript 構文の不合理で不正確な部分を削除し、奇妙な動作を軽減します。
コード操作の不安を解消し、コード操作の安全性を確保
コンパイラの効率を向上させ、実行速度を向上させます。
JavaScript の将来の新しいバージョンへの道を開く
厳密モードの制限事項
with文の使用を禁止する
this キーワードがグローバル オブジェクトを指すことを禁止します
宣言されていない変数、オブジェクト (オブジェクトも変数) は許可されません
変数、オブジェクト、関数を削除することはできません (x を削除するとエラーが報告されます)
同じ名前の変数は許可されず、オブジェクトが同じ名前のプロパティを持つことはできません
8 進数は使用できません、エスケープ文字は使用できません
読み取り専用プロパティへの割り当ては許可されず、ゲッター メソッドを使用して読み取られるプロパティへの割り当ても許可されません。
削除が許可されていない属性は削除できません
変数名には「eval」、「arguments」文字列を使用できません
セキュリティ上の理由から、スコープ eval() で作成された変数を呼び出すことはできません。
使用:
「use strict」ディレクティブは、スクリプトまたは関数の先頭でのみ許可されます。
// "use strict" 指令只允许出现在脚本或函数的开头
"use strict"
/* function fn(){
"use strict"
......
} */
// 1. 不允许使用with语句
// with (Math){x = cos(2)} //Uncaught SyntaxError: Strict mode code may not include a with statement
// 2. 禁止this关键字指向全局对象
function fn(){
console.log(this);
}
fn() // undefined
// 使用构造函数时,如果忘了加new,this不再指向全局对象,而是报错
function fun(){
this.a = 1
}
// fun() //Cannot set properties of undefined (setting 'a')
const a = new fun()
console.log(a); // fun {a: 1}
// 3. 不允许使用未声明的变量 对象也是一个变量
// pi = 3.14 // Uncaught ReferenceError: pi is not defined
// x = {p1:10, p2:20} //05-严格模式.js:8 Uncaught ReferenceError: pi is not defined
// 4. 不允许删除变量, 对象, 函数
/* var x = 1
function y(a){}
delete x
delete y */ //Uncaught SyntaxError: Delete of an unqualified identifier in strict mode
// 5. 不允许变量重名
// function q(a,a){} //Uncaught SyntaxError: Duplicate parameter name not allowed in this context
// 6. 不允许使用八进制
// var x = 010; //Uncaught SyntaxError: Octal literals are not allowed in strict mode
// 7. 不允许对只读属性赋值
/* var obj = {};
Object.defineProperty(obj, "x", {value:0, writable:false})
obj.x = 1 //Uncaught TypeError: Cannot assign to read only property 'x' of object '#<Object>' */
// 8. 不允许对一个使用getter方法读取的属性进行赋值
/* var obj = {get x() {return 0} };
obj.x = 3.14; //05-严格模式.js:30 Uncaught TypeError: Cannot set property x of #<Object> which has only a getter */
// 9. 不允许删除一个不允许删除的属性
// delete Object.prototype //05-严格模式.js:33 Uncaught TypeError: Cannot delete property 'prototype' of function Object() { [native code] }
// 10. 变量名不能使用 "eval", "arguments" 字符串
// var eval = 3.14
// var arguments = 3.14
//Uncaught SyntaxError: Unexpected eval or arguments in strict mode
// 11.由于一些安全原因,在作用域 eval() 创建的变量不能被调用
// eval ("var x = 2");
// alert (x); //Uncaught ReferenceError: x is not defined