在JS的继承中,属性的赋值操作首先是检查原型链,以此来判断是否允许赋值操作。如果o继承自一个只读属性x,那么赋值操作是不允许的。如果允许赋值操作,他也是总在原始对象上创建属性,或者对已有的属性赋值,而不会去修改原型链。即在JS中石油在查询属性时才会体会到继承的存在,而设置属性则和继承无关,借用随手记03中的createObjetc函数
举个栗子
var a ={r:1}
var b = Object.create(a)
b.x=1
b.y=1
b.r=3
b
//Object {x: 1, y: 1, r: 3}
a.r
//1
属性赋值要么失败,要么创建一个属性,要么在原始对象中设置属性,但是有一个意外
属性的删除
delete只是断开属性和对象的联系,而不会去操作属性中的属性
delete 只能删除自有属性,不能删除继承属性(要删除继承属性必须从定义这个属性的原型对象上删除它,而且这会影响到所有继承这个原型的对象)
属性检测
in 是判断该属性是否是自有属性
hasOwnProperty()判断是否是自有属性
propertyIsEnumerable 是hasOwnProperty的增强版,只有检测到是自有属性且这个属性是可枚举的(enumerable 为 true)才返回true
枚举属性
ECMAscript5中定义了两个新的得到一个对象的自有属性
一个是 Object.keys() 返回一个数组是自由属性中的可枚举属性
一个是Object.getOwnPropertyNames() 返回所有的自有属性名称
Object.keys()跟Object.getOwnPropertyNames() 运行原理差不多
Object.keys()的原理跟下面的例子差不多
function keys(o){
if(typeof o != "Object") throw TypeError();
var result = [];
for(var key in o){
if(o.hasOwnProperty(key)){
result.push(key);
}
}
return result;
}