第五版本
6.1.1 属性类型
1/数据属性 :包含有数据值的问题。有内部有特性和属性,是为了实现javaScript引擎用的,在javaScript中不能直接访问
[[Configurable]] :表示能否通过 delete 删除属性从而重新定义属性,能否修改属性的特
性,或者能否把属性修改为访问器属性。像前面例子中那样直接在对象上定义的属性,它们的
这个特性默认值为 true 。
? [[Enumerable]] :表示能否通过 for-in 循环返回属性。像前面例子中那样直接在对象上定
义的属性,它们的这个特性默认值为 true 。
? [[Writable]] :表示能否修改属性的值。像前面例子中那样直接在对象上定义的属性,它们的
这个特性默认值为 true 。
? [[Value]] :包含这个属性的数据值。读取属性值的时候,从这个位置读;写入属性值的时候,
把新值保存在这个位置。这个特性的默认值为 undefined 。
若修改特性,则可通过提供的Object.defineProperty()方法,此方法接收三个参数:对象,对象属性名,描述符对象。案例
//Object.defineProperty()不建议在IE8中使用
var person = {};
Object.defineProperty(person, "name", {
writable: false,
value: "Nicholas"
});
alert(person.name); //"Nicholas"
person.name = "Greg";
alert(person.name); //"Nicholas"
//把 configurable 设置为 false ,表示不能从对象中删除属性。如果对这个属性调用 delete ,则
//在非严格模式下什么也不会发生,而在严格模式下会导致错误。而且,一旦把属性定义为不可配置的,
//就不能再把它变回可配置了。此时,再调用 Object.defineProperty() 方法修改除 writable 之外
的特性,都会导致错误:
var person = {};
Object.defineProperty(person, "name", {
configurable: false,
value: "Nicholas"
});
//抛出错误
Object.defineProperty(person, "name", {
configurable: true,
value: "Nicholas"
});
2/访问属性
? [[Configurable]] :表示能否通过 delete 删除属性从而重新定义属性,能否修改属性的特
性,或者能否把属性修改为数据属性。对于直接在对象上定义的属性,这个特性的默认值为true 。
? [[Enumerable]] :表示能否通过 for-in 循环返回属性。对于直接在对象上定义的属性,这
个特性的默认值为 true 。
? [[Get]] :在读取属性时调用的函数。默认值为 undefined 。
? [[Set]] :在写入属性时调用的函数。默认值为 undefined
访问器属性不能直接定义,必须要用Object.defineProperty()来定义。案例:
var book = {
_year: ,
edition:
};
Object.defineProperty(book, "year", {
get: function(){
return this._year;
},
set: function(newValue){
if (newValue > ) {
this._year = newValue;
this.edition += newValue - ;
}
}
});
book.year = ;
alert(book.edition); //2
6.1.2定义多属性
Object.defineProperties()方法:可以通过描述符定义多个属性(IE9+才能用)。案例
var book = {};
Object.defineProperties(book, {
_year: {
value:
},
edition: {
value:
},
year: {
get: function(){
return this._year;
},
set: function(newValue){
if (newValue > ) {
this._year = newValue;
his.edition += newValue - ;
}
}
}
});
6.1.3读取属性
Object.getOwnPropertyDescriptor():可以取到给定属性的描述符。
var book = {};
Object.defineProperties(book, {
_year: {
value: 2004
},
edition: {
value: 1
},
year: {
get: function(){
return this._year;
},
set: function(newValue){
if (newValue > 2004) {
this._year = newValue;
this.edition += newValue - 2004;
}
}
}
});
[[Configurable]] :表示能否通过 delete 删除属性从而重新定义属性,能否修改属性的特性,或者能否把属性修改为数据属性。对于直接在对象上定义的属性,这个特性的默认值为true 。 [[Enumerable]] :表示能否通过 for-in 循环返回属性。对于直接在对象上定义的属性,这个特性的默认值为 true 。 [[Get]] :在读取属性时调用的函数。默认值为 undefined 。 [[Set]] :在写入属性时调用的函数。默认值为 undefined 。