JavaScript原生提供一个Object对象,所有其他对象都继承自这个对象。
object.keys()与object.getOwnPropertyNames()
用来遍历对象的属性。他们的参数都是一个对象,都返回一个数组,该数组的成员都是对象自身的所有属性名。区别在于object.getOwnPropertyNames()还返回不可枚举的属性名,如length
(1) 对象属性模型的相关方法
Object.getOwnPropertyDescriptor():获取某个属性的attributes对象。
Object.defineProperty():通过attributes对象,定义某个属性。
var o = {};
Object.defineProperty (o,'p',{
value:123,
get:function() { return456;}
});
Object.defineProperties():通过attributes对象,定义多个属性。
var o = Object.defineProperties ( { }, {
p1:{value:123,enumerable:true},
p2:{value:'abc',enumerable:true},
p3:{ get:function(){returnthis.p1+this.p2},
enumerable:true,
configurable:true}
});
o.p1// 123
o.p2// "abc"
o.p3// "123abc"
Object.getOwnPropertyNames():返回直接定义在某个对象上面的全部属性的名称。
var 0 = Object.defineProperties({},{
p1:{ value:1,enumerable:true };
p2:{ value:2,enumerable:false }
});
Object.getOwnPropertyNames(o)
// ["p1","p2"] 返回直接定义在该对象上的全部属性的名称
可配置性(configurable)
可配置性(configurable)决定了是否可以修改属性的描述对象。也就是说,当configurable为false的时候,value、writable、enumerable和configurable都不能被修改了。
可写性(writable)决定了属性的值(value)是否可以被改变。
而不使用var命令声明变量时(或者使用属性赋值的方式声明变量),变量的可配置性为true。
如果一个变量是使用var命令生成的,就无法用delete命令删除。也就是说,delete只能删除对象的属性。
存取器(accessor)
其中,存值函数称为setter,使用set命令;取值函数称为getter,使用get命令。
(2) 控制对象状态的方法
Object.preventExtensions():防止对象扩展。使一个对象无法再添加新的属性;可以用delete命令删除现有属性。
Object.isExtensible():判断对象是否可扩展。(返回true,表示可以添加新属性)
Object.seal():禁止对象配置。
Object.isSealed():判断一个对象是否可配置
Object.freeze():冻结一个对象。
Object.isFrozen():判断一个对象是否被冻结。
(3) 原型链相关方法
Object.create():生成一个新对象,并该对象的原型。
Object.getPrototypeOf():获取对象的prototype对象
Object实例对象的方法:
valueOf():返回当前对象对应的值;
toString():返回当前对象对应的本地字符串形式;
toLocalString():
hasOwnProperty():
isPrototypeOf():
propertylsEnumerable():
toString()判断数据类型: