五、內部屬性類型:內部屬性無法直接訪問,ECMAScript5把它們放在兩對方括號中,分為數據屬性和訪問器屬性
[1]數據屬性包含一個數據值的位置,在這個位置可以讀取和寫入值。數據屬性有4個特性:
a、[[Configurable]]: 表示能否通過delete刪除屬性從而重新定義屬性,能否修改屬性的特性,或者能否把屬性修改為訪問器屬性,直接在對象上定義的屬性,默認值為true
b、[[Enumerable]]: 表示能否通過for-in循環返回屬性,直接在對象上定義的屬性,默認值為true
c、[[Writable]]: 表示能否修改屬性的值,直接在對象上定義的屬性,默認值為true
d、[[Value]]: 包含這個屬性的數據值,讀取屬性值的時候,從這個位置讀;寫入屬性值的時候,把新值保存在這個位置。直接在對象上定義的屬性,默認值為undefined
[2]訪問器屬性不包含數據值,包含一對getter和setter函數(不過這兩個函數不是必需的)。讀取訪問器屬性時,會調用getter函數,這個函數負責返回有效的值;在寫入訪問器屬性時,會調用setter函數并傳入新值,這個函數負責決定如何處理函數。訪問器屬性有如下4個特性:
a、[[Configurable]]: 表示能否通過delete刪除屬性從而重新定義屬性,能否修改屬性的特性,或者能否把屬性修改為訪問器屬性。直接在對象上定義的屬性,默認值為true
b、[[Enumerable]]: 表示能否通過for-in循環返回屬性,直接在對象上定義的屬性,默認值為true
c、[[Get]]: 在讀取屬性時調用的函數。默認值為undefined
d、[[Set]]: 在寫入屬性時調用的函數。默認值為undefined
六、修改內部屬性:使用ECMAScript5的object.defineProperty()方法,該方法接收三個參數:屬性所在的對象、屬性的名字和一個描述符對象
[注意1]IE8是第一個實現Object.defineProperty()方法的瀏覽器版本。然而,這個版本的實現存在諸多限制:只能在DOM對象上使用這個方法,而且只能創建訪問器屬性。由于實現不徹底,不建議在IE8中使用Object.defineProperty()方法
[注意2]不支持Object.defineProperty()方法的瀏覽器中不能修改[[Configurable]]和[[Enumerable]]
[1]修改數據屬性
//不是在對象上定義的屬性,Configurable、Enumerable、Writable為false var person = {}; Object.defineProperty(person,'name',{ value: 'Nicholas' }); alert(person.name);//'Nicholas' person.name = 'Greg'; alert(person.name);//'Nicholas'
[注意]一旦把屬性定義為不可配置的,就不能再把它變回可配置了,也就是說可以多次調用Object.defineProperty()修改同一屬性,但在把configurable設置為false之后,就有限制了
[2]修改訪問器屬性
[注意1]只指定getter意味著屬性是不能寫
[注意2]只指定setter意味著屬性不能讀
【補充】創建訪問器屬性的用兩個非標準的方法:__defineGetter__()和__defineSetter__()
七、定義多個屬性:ECMAScript5定義了一個Object.defineProperties()方法,利用這個方法可以通過描述符一次定義多個屬性,這個方法接收兩個對象參數:第一個對象是要添加和修改其屬性的對象,第二個對象的屬性與第一個對象要添加或修改的一一對應
八、讀取屬性特性:使用ECMAScript5的Object.getOwnPropertyDescriptor()方法,可以取得給定屬性的描述符。該方法接收兩個參數:屬性所在對象和要讀取其描述符的屬性名稱,返回值是一個對象。
[注意]可以針對任何對象——包括DOM和BOM對象,使用Object.getOwnPropertyDescriptor()方法
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com