1.基本概念
JS对象:无序属性的集合,其属性可以包含基本值、对象或函数。属性又分为数据属性和访问器属性。
ECMAScript为了描述对象属性(property)的各种特征,定义了特性(attribute)这个概念。
2.数据和访问器
数据特征 | 含义 |
---|---|
[[Configurable]] | 表示能否通过delete删除属性从而重新定义属性,能否修改属性的特性,或者能否把属性修改为访问器属性。 |
[[Enumerable]] | 表示是否是可枚举类型(能否用for-in循环返回属性)。 |
[[Writable]] | 表示能否修改数据值。 |
[[Value]] | 包含这个属性的数据值,读写都在这个特征值上进行。默认undefined。 |
访问器特征 | 含义 |
---|---|
[[Configurable]] | 表示能否通过delete删除属性从而重新定义属性,能否修改属性的特性,或者能否把属性修改为访问器属性。 |
[[Enumerable]] | 表示是否是可枚举类型(能否用for-in循环返回属性)。 |
[[Get]] | 在读取属性时调用的函数。默认undefined。 |
[[Set]] | 在写入属性时调用的函数。默认undefined。 |
- 获取特征的方法
var person = {
name: "FAFA",
age: 18
}
Object.getOwnPropertyDescriptor(person,"name");
3.设置和访问的方式
- 设置特征
var person = {
name: "FAFA",
age: 18
}
Object.defineProperty(person,"name",{
configurable : true,
enumerable : false,
writable : true
});
for(var i in person){
console.log(i);//只有age被枚举到
}
- 同时设置多个属性的特征
var person = {
name: "FAFA",
age: 18
}
//同时设置多个属性的特征
Object.defineProperties(person,{
name:{
configurable : true,
enumerable : false,
writable : true
},
age:{
configurable : true,
enumerable : false,
writable : true
}
});
for(var i in person){
console.log(i);//都枚举不到
}
- 设置访问器的特征
var person = {
name : "FAFA",
_age : 18,
edition : 0
}
Object.defineProperty(person,"age",{
get : function(){
return this._age;
},
set :function(n){//值指定get不指定set则默认该属性是只读的。
this._age = n;
this.edition ++;
}
});
//只指定getter意味着属性时不能写,尝试写入属性会被忽略、
//在严格模式下,尝试写入只制定了getter函数的属性会抛出错误。
//只指定了setter函数的属性也不能读,否则在非严格模式下返回undefined。
//在严格模式下会抛出错误。