DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JavaScript中的對象的extensible屬性介紹
JavaScript中的對象的extensible屬性介紹
編輯:關於JavaScript     

JavaScript中,對象的extensible屬性用於表示是否允許在對象中動態添加新的property。ECMAScript 3標准中,所有的對象都是extensible的。ECMAScript 5標准中,所有的對象默認仍是extensible的,但可以通過設定來改變這一屬性。

查詢一個對象是否是extensible的,可以使用Object.isExtensible()語句:


復制代碼 代碼如下:
var o = {x:1};
console.log(Object.isExtensible(o));//true


使一個對象變成不是extensible的,可以使用Object.preventExtensions()語句:


復制代碼 代碼如下:
Object.preventExtensions(o)
console.log(Object.isExtensible(o));//false


值得注意的是,由於沒有Object.preventExtensions()的反操作語句,因此一旦某個對象被設定為非extensible後,將沒有辦法重新再將其設定為extensible。

Object.preventExtensions()語句作用的范圍是對象自身,原型對象不受影響。如果某個對象被設定為非extensible,那麼其原型對象中依然可以動態添加property,而這些動態添加的property也依然可以被對象繼承到。

Object.seal()和Object.freeze()

Object.preventExtensions()可以防止在對象中動態添加新的property。除了這個操作,JavaScript中還存在另外兩個更加嚴格的操作來保護對象:Object.seal()和Object.freeze()。

Object.seal()的作用是在Object.preventExtensions()的基礎上,設定所有對象自身property的configurable屬性為false。與Object.preventExtensions()操作一樣,Object.seal()沒有反操作,因此一旦將對象seal了之後將無法恢復其狀態。在JavaScript中,可以通過Object.isSealed()來查詢某個對象是否被seal了。

Object.freeze()的作用是在Object.seal()的基礎上,將所有對象自身的property設定為只讀。與Object.seal()和Object.preventExtensions()操作一樣,Object.freeze()沒有反操作,因此一旦將對象freeze了之後將無法恢復其狀態。在JavaScript中,可以通過Object.isFrozen()來查詢某個對象是否被freeze了。


復制代碼 代碼如下:
console.log(Object.isSealed(o));//false
Object.seal(o);
console.log(Object.isSealed(o));//true
console.log(Object.isFrozen(o));//false
Object.freeze(o);
console.log(Object.isFrozen(o));//true


無論是Object.preventExtensions(),還是Object.seal()和Object.freeze(),其作用范圍均為對象自身,對象的原型對象將不受影響。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved