1.概述
除了正常運(yùn)行模式挠唆,ECMAscript 5添加了第二種運(yùn)行模式:"嚴(yán)格模式"(strict mode)贿条。顧名思義雹仿,這種模式使得Javascript在更嚴(yán)格的條件下運(yùn)行。
2.為什么用嚴(yán)格模式
消除Javascript語(yǔ)法的一些不合理整以、不嚴(yán)謹(jǐn)之處胧辽,減少一些怪異行為;消除代碼運(yùn)行的一些不安全之處,保證代碼運(yùn)行的安全公黑;提高編譯器效率邑商,增加運(yùn)行速度摄咆;為未來新版本的Javascript做好鋪墊。
"嚴(yán)格模式"體現(xiàn)了Javascript更合理人断、更安全豆同、更嚴(yán)謹(jǐn)?shù)陌l(fā)展方向,包括IE 10在內(nèi)的主流瀏覽器含鳞,都已經(jīng)支持它,許多大項(xiàng)目已經(jīng)開始全面擁抱它芹务。
另一方面蝉绷,同樣的代碼,在"嚴(yán)格模式"中枣抱,可能會(huì)有不一樣的運(yùn)行結(jié)果熔吗;一些在"正常模式"下可以運(yùn)行的語(yǔ)句,在"嚴(yán)格模式"下將不能運(yùn)行佳晶。掌握這些內(nèi)容桅狠,有助于更細(xì)致深入地理解Javascript,讓你變成一個(gè)更好的程序員轿秧。
3.進(jìn)入標(biāo)志
"use strict";
4.如何調(diào)用
4.1針對(duì)單個(gè)腳本
? ? "use strict";
"use strict";
????console.log("這是嚴(yán)格模式中跌。");
4.2針對(duì)單個(gè)函數(shù)
function strict(){
"use strict";
return"這是嚴(yán)格模式。";
}
function notStrict() {
return"這是正常模式菇篡。";
}
5.語(yǔ)法與行為改變
嚴(yán)格模式對(duì)Javascript的語(yǔ)法和行為漩符,都做了一些改變。
5.1 全局變量顯式聲明
在正常模式中驱还,如果一個(gè)變量沒有聲明就賦值嗜暴,默認(rèn)是全局變量。嚴(yán)格模式禁止這種用法议蟆,全局變量必須顯式聲明闷沥。
"use strict";
v = 1;// 報(bào)錯(cuò),v未聲明for(i = 0; i < 2; i++) {// 報(bào)錯(cuò)咐容,i未聲明}
因此舆逃,嚴(yán)格模式下,變量都必須先用var命令聲明疟丙,然后再使用颖侄。
5.2?禁止this關(guān)鍵字指向全局對(duì)象
function f(){
return!this;
}
// 返回false,因?yàn)?this"指向全局對(duì)象享郊,"!this"就是falsefunction f(){
"use strict";
return!this;
}
// 返回true览祖,因?yàn)閲?yán)格模式下,this的值為undefined炊琉,所以"!this"為true展蒂。
因此又活,使用構(gòu)造函數(shù)時(shí),如果忘了加new锰悼,this不再指向全局對(duì)象柳骄,而是報(bào)錯(cuò)。
function f(){
"use strict";
this.a = 1;
};
f();// 報(bào)錯(cuò)箕般,this未定義
5.3禁止刪除變量
嚴(yán)格模式下無(wú)法刪除變量耐薯。只有configurable設(shè)置為true的對(duì)象屬性,才能被刪除丝里。
"use strict";
var x;
deletex;// 語(yǔ)法錯(cuò)誤varo = Object.create(null, {'x': {
value: 1,
configurable: true }});
deleteo.x;// 刪除成功
5.4對(duì)象不能有重名的屬性
正常模式下曲初,如果對(duì)象有多個(gè)重名屬性,最后賦值的那個(gè)屬性會(huì)覆蓋前面的值杯聚。嚴(yán)格模式下臼婆,這屬于語(yǔ)法錯(cuò)誤。
"use strict";
varo = {
p: 1,
p: 2 }; // 語(yǔ)法錯(cuò)誤
5.5函數(shù)不能有重名的參數(shù)
正常模式下幌绍,如果函數(shù)有多個(gè)重名的參數(shù)颁褂,可以用arguments[i]讀取。嚴(yán)格模式下傀广,這屬于語(yǔ)法錯(cuò)誤颁独。
"use strict";
functionf(a, a, b) {// 語(yǔ)法錯(cuò)誤return ;
}