ECMAScript 5嚴(yán)格模式(Strict Mode)介紹
嚴(yán)格模式(Strict Mode)是ECMAScript 5的新特性,它允許你把整個(gè)程序,或者某個(gè)函數(shù),放置在“嚴(yán)格”的操作語境中。這種嚴(yán)格的語境會(huì)防止某些特定的操作并拋出更多的異常。
雖然ECMAScript 5對(duì)ECMAScript 3是向下兼容的,但是在嚴(yán)格模式下,所有在ECMAScript 3中不贊成使用的特性都被禁用(或拋出錯(cuò)誤)而不是兼容。
啟用嚴(yán)格模式有以下好處:
1.捕獲一些編程錯(cuò)誤,并拋出異常。
2.阻止進(jìn)行一些相對(duì)“不安全”的操作(例如訪問全局變量),拋出異常。
3.禁用一些讓人迷惑的特性。
關(guān)于嚴(yán)格模式的大多數(shù)信息都可以在《ES5規(guī)范》[PDF]的第223頁找到。
(注意:ECMAScript 5的嚴(yán)格模式跟Firefox的嚴(yán)格模式是不同的)
如何啟用嚴(yán)格模式
在程序的開頭添加這條語句即可對(duì)整段腳本啟用嚴(yán)格模式:
'use strict';
也可以只在函數(shù)的內(nèi)部啟用嚴(yán)格模式,這樣不會(huì)影響到外部:
function imStrict() {
'use strict';
// ... your code ...
}
啟用嚴(yán)格模式的語句只是一段普通的字符串“use strict”,沒有任何新語法。這意味著不會(huì)對(duì)就舊式瀏覽器造成任何負(fù)面影響。
在函數(shù)內(nèi)部啟用嚴(yán)格模式的一個(gè)實(shí)際應(yīng)用是,把整個(gè)Javascript類庫定義在嚴(yán)格模式的函數(shù)內(nèi)部,這樣就可以不影響外部的代碼:
// Non-strict code...
(function(){
"use strict";
// Define your library strictly...
})();
// Non-strict code...
那么,嚴(yán)格模式下的腳本有什么改變呢?
變量和屬性
對(duì)未定義變量的賦值將會(huì)失敗,而不是把這個(gè)變量作為全局變量。
寫入一個(gè)可寫特性為false的屬性,刪除一個(gè)可配置特性為false的屬性,或者添加一個(gè)可擴(kuò)展特性為false的屬性,都會(huì)導(dǎo)致錯(cuò)誤(這些特性是預(yù)先商定好的)。過去,這些操作不會(huì)拋出異常,僅僅是靜默地失敗。
對(duì)變量、函數(shù)或者函數(shù)參數(shù)執(zhí)行delete操作會(huì)導(dǎo)致錯(cuò)誤。
var foo = 'test';
function test() { }
delete foo; // Error
delete test; // Error
function test2(arg) {
delete arg; // Error
}
在一個(gè)對(duì)象容器內(nèi)部定義相同屬性會(huì)導(dǎo)致異常的拋出:
// Error
{ foo: true, foo: false }
eval
任何對(duì)“eval”這個(gè)名字的使用(主要意圖是把eval函數(shù)指向一個(gè)變量或者是對(duì)象的屬性)都是禁止的。
// All generate errors...
obj.eval = ...
obj.foo = eval;
var eval = ...;
for ( var eval in ... ) {}
function eval(){}
function test(eval){}
function(eval){}
new Function("eval")
另外,通過eval聲明新變量也會(huì)無效:
eval("var a = false;");
print( typeof a ); // undefined
函數(shù)
重寫arguments對(duì)象會(huì)導(dǎo)致錯(cuò)誤:
arguments = [...]; // not allowed
同名參數(shù)會(huì)導(dǎo)致錯(cuò)誤:
(function(foo, foo) { }) // Error
對(duì)arguments.caller和arguments.callee的訪問會(huì)拋出異常。因此,任何需要用到的匿名函數(shù)都必須先命名,例如:
setTimeout(function later(){
// do stuff...
setTimeout(later, 1000);
}, 1000 );
函數(shù)的arguments、caller和callee屬性不再存在,定義它們的操作也是禁止的。
function test() { }
test.caller = 'caller'; // Error
最后,一個(gè)長期存在(且非常討厭)的BUG已經(jīng)被解決了:當(dāng)使用null或者undefined作為Function.prototype.call或Function.prototype.apply方法的第一個(gè)參數(shù)時(shí),函數(shù)內(nèi)部的this將會(huì)指向全局對(duì)象。而嚴(yán)格模式將會(huì)阻止其執(zhí)行并拋出異常:
(function(){ ... }).call(null); // Exception
with() { }
with() { }語句在嚴(yán)格模式下是完全掛掉了。
相關(guān)文章
JavaScript DOM學(xué)習(xí)第四章 getElementByTagNames
HTML有一些相關(guān)有不同tag名字的相關(guān)元素,比如H1-H6或者input,select和TEXTAREA。getElementByTagName只能取得那些有相同tag名稱的元素,所以你不能用他來取得所有的標(biāo)題或者整個(gè)表單內(nèi)容。2010-02-02
JavaScript之?dāng)?shù)組(Array)詳解
這篇文章主要介紹了JavaScript之?dāng)?shù)組(Array)詳解,本文詳細(xì)講解了JavaScript數(shù)組的創(chuàng)建、檢測(cè)數(shù)組、轉(zhuǎn)化方法、棧方法、隊(duì)列方法、重排序方法、操作方法、位置方法等內(nèi)容,需要的朋友可以參考下2015-04-04
JavaScript那些不經(jīng)意間發(fā)生的數(shù)據(jù)類型自動(dòng)轉(zhuǎn)換
JavaScript可以自由的進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換,但是更多的情況下,是由JavaScript自動(dòng)轉(zhuǎn)換的。本文就將為大家詳細(xì)講解那些不經(jīng)意間發(fā)生的數(shù)據(jù)類型轉(zhuǎn)換,感興趣的同學(xué)可以了解一下2022-02-02
轉(zhuǎn)義字符(\)對(duì)JavaScript中JSON.parse的影響概述
JSON是一個(gè)提供了stringify和parse方法的內(nèi)置對(duì)象,前者用于將js對(duì)象轉(zhuǎn)化為符合json標(biāo)準(zhǔn)的字符串,后者將符合json標(biāo)準(zhǔn)的字符串轉(zhuǎn)化為js對(duì)象,本文為大家介紹下轉(zhuǎn)義字符對(duì)JSON.parse方法的影響2013-07-07
JavaScript 對(duì)話框和狀態(tài)欄使用說明
平時(shí)工作中,無論是調(diào)試 javascript 代碼還是進(jìn)行頁面提示,我們都會(huì)經(jīng)常使用 javascript 的對(duì)話框。除了創(chuàng)建明確不使用狀態(tài)欄的瀏覽器窗口,每個(gè)瀏覽器窗口的底部都有一個(gè)狀態(tài)欄,用來向用戶顯示一些特定的消息。2009-10-10
JavaScript基礎(chǔ)之立即執(zhí)行函數(shù)
這篇文章主要介紹了如何理解JavaScript中的立即執(zhí)行函數(shù),幫助大家更好的學(xué)習(xí)JavaScript,感興趣的朋友可以了解下2021-11-11

