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(),其作用范圍均為對象自身,對象的原型對象將不受影響。