Javascript use strict
ECMAscript 5添加了第二種支行模式:嚴格模式(strict mode)。
- 針對單個指令碼
<script>
"use strict";
console.log("這是嚴格模式。");
</script>
- 針對單個函式
function strict(){
"use strict";
return "這是嚴格模式。";
}
function notStrict() {
return "這是正常模式。";
}
- 全域性變數顯示宣告
在正常模式中,如果一個變數沒有宣告就賦值,預設是全域性變數。嚴格模式禁止這種用法,全域性變數必須宣告。
"use strict";
v = 1; // 報錯,v未宣告
for(i = 0; i < 2; i++) { // 報錯,i未宣告
}
- 禁止this關鍵字指向全域性物件
function f(){
return !this;
}
// 返回false,因為"this"指向全域性物件,"!this"就是false
function f(){
"use strict";
return !this;
}
// 返回true,因為嚴格模式下,this的值為undefined,所以"!this"為true。
- 禁止刪除變數
嚴格模式下無法刪除變數,只有configurable設定為true的物件屬性,才能刪除 。
"use strict";
var x;
delete x; // 語法錯誤
var o = Object.create(null, {'x': {
value: 1,
configurable: true
}});
delete o.x; // 刪除成功
- 函式不能有重名的引數
正常模式下,如果函式有多個重名的引數,可以用arguments[i]讀取,嚴格模式下,這屬於語法錯誤。
"use strict";
function f(a, a, b) { // 語法錯誤
return ;
}
最後歡迎大家訪問我的個人網站:1024s