您的位置:首页 > 其它

犀牛书随手记-04

2016-01-10 22:23 281 查看
在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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: