所以Object.prototype返回。
代码
1. var val = objectRef.madeUpProperty;
最后val是undefined,因为MyObject1和MyObject2,还有Object都没有定义madeUpProperty这个property,所以得到的是undefine.
读操作会读取在obj自己和prototype 链上发现的第一个同名属性值
写操作会为obj对象本身创建一个同名属性(如果这个属性名不存在
这就意味着objectRef.testNumber = 3会在objectRef对象上创建一个property,名字是testNumber,当下一次在要读取testNumber时
propertype链就不会工作,仅仅会得到objectRef的property 3,而MyObject1的testNumber属性并不会被修改。下面的代码可以验证
代码
1. /* 构建MyObject1这个类型的构造函数
2. MyObject1 - type.
3. */
4. function MyObject1(formalParameter){
5. /* 为者对象创建一个属性名字叫testNumber
6. */
7. this.testNumber = formalParameter;
8. }
9.
10. /* 构建MyObject2这个类型的构造函数
11. MyObject2 - type:-
12. */
13. function MyObject2(formalParameter){
14. /* 为者对象创建一个属性名字叫testString*/
15. this.testString = formalParameter;
16. }
17.
18. /* 下一步的操作会用MyObject1对象替换掉MyObject2默认的prototype属性*/
19. var obj1 = new MyObject1( 8 );
20. MyObject2.prototype = obj1;
21.
22. /* 最后我们创建MyObject2类型的一个对象*/
23.
24. var objectRef = new MyObject2( "String_Value" );
25.
26. alert(objectRef.testNumber);
27. objectRef.testNumber = 5;
28. alert(objectRef.testNumber);
29. alert(obj1.testNumber);










