犀牛书随手记-04

来源:互联网 发布:阿里云二级域名注册 编辑:程序博客网 时间:2024/05/17 22:22

在JS的继承中,属性的赋值操作首先是检查原型链,以此来判断是否允许赋值操作。如果o继承自一个只读属性x,那么赋值操作是不允许的。如果允许赋值操作,他也是总在原始对象上创建属性,或者对已有的属性赋值,而不会去修改原型链。即在JS中石油在查询属性时才会体会到继承的存在,而设置属性则和继承无关,借用随手记03中的createObjetc函数
举个栗子

var a ={r:1}var b = Object.create(a)b.x=1b.y=1b.r=3b//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;    }
0 0