日期:2014-05-16  浏览次数:20276 次

JavaScript对象模型-执行模型(笔记2)

本地属性与继承属性
对象通过隐式Prototype链能够实现属性和方法的继承,但prototype(隐式的)也是一个普通对象,就是说它是一个普通的实例化的对象,而不是纯粹抽象的数据结构描述。所以就有了这个本地属性与继承属性的问题。//自己定义的属性和继承过来的属性
首先看一下设置对象属性时的处理过程。JS定义了一组attribute,用来描述对象的属性property,以表明属性property是否可以在JavaScript代码中设值、被for in枚举等。
obj.propName=value的赋值语句处理步骤如下:
1. 如果propName的attribute设置为不能设值,则返回
2. 如果obj.propName不存在,则为obj创建一个属性,名称为propName
3. 将obj.propName的值设为value
可以看到,设值过程并不会考虑Prototype链,道理很明显,obj的内部[[Prototype]]是一个实例化的对象,它不仅仅向obj共享属性,还可能向其它对象共享属性,修改它可能影响其它对象
用上面CF, Cfp的示例来说明,实例对象cf1具有本地属性q1, q2以及继承属性CFP1,如果执行cf1.CFP1="",那么cf1就具有本地属性CFP1了,测试结果如下:

//Passed?in?FF2.0,?IE7,?Opera9.25,?Safari3.0.4
var?cf1=new?CF("aaa",?"bbb");
var?cf2=new?CF(111,?222);
document.write(cf1.CFP1?
+?"<br?/>");?//result:?CFP1?in?Cfp
document.write(cf2.CFP1?+?"<br?/>");?//result:?CFP1?in?Cfp
//it will result in a local property in cf1
cf1.CFP1="new?value?for?cf1";//给sf1赋了个本地对象cfp1,在使用cf1.CFP1的时候就优先寻找这个cfp1
//changes on CF.prototype.CFP1 will affect cf2 but not cf1, because there's already a local property with
//the name CFP1 in cf1, but no such one in cf2
CF.prototype.CFP1="new?value?for?Cfp";
document.write(cf1.CFP1?
+?"<br?/>