首頁  >  文章  >  web前端  >  ECMAScript 5嚴格模式(Strict Mode)介紹_基礎知識

ECMAScript 5嚴格模式(Strict Mode)介紹_基礎知識

WBOY
WBOY原創
2016-05-16 16:11:421272瀏覽

嚴格模式(Strict Mode)是ECMAScript 5的新特性,它允許你把整個程序,或某個函數,放置在「嚴格」的操作情境中。這種嚴格的語境會防止某些特定的操作並拋出更多的異常。

雖然ECMAScript 5對ECMAScript 3是向下相容的,但是在嚴格模式下,所有在ECMAScript 3中不贊成使用的特性都被禁用(或拋出錯誤)而不是相容。

啟用嚴格模式有以下好處:

1.捕獲一些程式錯誤,並拋出異常。
2.阻止進行一些相對「不安全」的操作(例如存取全域變數),拋出異常。
3.禁用一些讓人迷惑的特性。

關於嚴格模式的大多數資訊都可以在《ES5規範》[PDF]的第223頁找到。

(註:ECMAScript 5的嚴格模式跟Firefox的嚴格模式是不同的)

如何啟用嚴格模式

在程式的開頭加入這條語句即可對整段腳本啟用嚴格模式:

複製程式碼 程式碼如下:

'use strict';

也可以只在函數的內部啟用嚴格模式,這樣不會影響到外部:
複製程式碼 程式碼如下:

function imStrict() {
  'use strict';
  // ... your code ...
}

啟用嚴格模式的語句只是一段普通的字串“use strict”,沒有任何新語法。這意味著不會對就舊式瀏覽器造成任何負面影響。

在函數內部啟用嚴格模式的一個實際應用是,把整個Javascript類別庫定義在嚴格模式的函數內部,這樣就可以不影響外部的程式碼:

複製程式碼 程式碼如下:

// Non-strict code...

(function(){
  "use strict";

  // Define your library strictly...
})();

// Non-strict code...


那麼,嚴格模式下的腳本有什麼改變呢?

變數與屬性

對未定義變數的賦值將會失敗,而不是把這個變數當作全域變數。

寫入一個可寫入特性為false的屬性,刪除一個可配置特性為false的屬性,或是新增一個可擴充特性為false的屬性,都會導致錯誤(這些特性是預先約定好的)。過去,這些操作不會拋出異常,只是靜默地失敗。

對變數、函數或函數參數執行delete操作會導致錯誤。

複製程式碼 程式碼如下:

var foo = 'test';
function test() { }

delete foo; // Error
delete test; // Error

function test2(arg) {
  delete arg; // Error
}


在一個物件容器內部定義相同屬性會導致異常的拋出:
複製程式碼 程式碼如下:

// Error
{ foo: true, foo: false }

eval

任何對「eval」這個名字的使用(主要意圖是把eval函數指向一個變數或是物件的屬性)都是禁止的。

複製程式碼 程式碼如下:

// 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宣告新變數也會無效:
複製程式碼 程式碼如下:

eval("var a = false;");
print( typeof a ); // undefined

函數

重寫arguments物件會導致錯誤:

複製程式碼 程式碼如下:

arguments = [...]; // not allowed

同名參數會導致錯誤:
複製程式碼 程式碼如下:

(function(foo, foo) { }) // Error

對arguments.caller和arguments.callee的訪問會拋出異常。因此,任何需要用到的匿名函數都必須先命名,例如:
複製程式碼 程式碼如下:

setTimeout(function later(){
  // do stuff...
  setTimeout(later, 1000);
}, 1000 );

函數的arguments、caller和callee屬性不再存在,定義它們的操作也是禁止的。
複製程式碼 程式碼如下:

function test() { }
test.caller = 'caller';  // Error

最後,一個長期存在(且非常討厭)的BUG已經被解決了:當使用null或undefined作為Function.prototype.call或Function.prototype.apply方法的第一個參數時,函數內部的this將會指向全局對象。而嚴格模式將會阻止其執行並拋出異常:
複製程式碼 程式碼如下:

(function(){ ... }).call(null); // Exception

with() { }

with() { }語句在嚴格模式下是完全掛掉了。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn