欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中的對象的extensible屬性介紹

 更新時(shí)間:2014年12月30日 09:22:13   投稿:junjie  
這篇文章主要介紹了JavaScript中的對象的extensible屬性介紹,JavaScript中,對象的extensible屬性用于表示是否允許在對象中動態(tài)添加新的property,需要的朋友可以參考下

JavaScript中,對象的extensible屬性用于表示是否允許在對象中動態(tài)添加新的property。ECMAScript 3標(biāo)準(zhǔn)中,所有的對象都是extensible的。ECMAScript 5標(biāo)準(zhǔn)中,所有的對象默認(rèn)仍是extensible的,但可以通過設(shè)定來改變這一屬性。

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


復(fù)制代碼 代碼如下:

var o = {x:1};
console.log(Object.isExtensible(o));//true


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


復(fù)制代碼 代碼如下:

Object.preventExtensions(o)
console.log(Object.isExtensible(o));//false


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

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

Object.seal()和Object.freeze()

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

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

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


復(fù)制代碼 代碼如下:

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

相關(guān)文章

最新評論