<code><script type="text/javascript"> function Person(){} Person.prototype.array = new Array("Koji", "Luo"); Person.prototype.showArray = function(){ alert(this.array); } var obj1 = new Person(); //生成一个Person对象 var obj2 = new Person(); obj1.array.push("Kyo"); //向obj1的array属性添加一个元素 obj1.showArray(); //Koji,Luo,Kyo obj2.showArray(); //Koji,Luo,Kyo </script> </code>
obj1的array中添加一个元素,obj2的array中也会添加.
他们俩继承的array是一个指针吗? 大家都有的是prototype这个对象中的array?
<code>//最后问一个很奇怪的问题(prototype中的array难道也只是一个指针?) </code>
谢谢大家..
<code><script type="text/javascript"> function Person(){} Person.prototype.array = new Array("Koji", "Luo"); Person.prototype.showArray = function(){ alert(this.array); } var obj1 = new Person(); //生成一个Person对象 var obj2 = new Person(); obj1.array.push("Kyo"); //向obj1的array属性添加一个元素 obj1.showArray(); //Koji,Luo,Kyo obj2.showArray(); //Koji,Luo,Kyo </script> </code>
obj1的array中添加一个元素,obj2的array中也会添加.
他们俩继承的array是一个指针吗? 大家都有的是prototype这个对象中的array?
<code>//最后问一个很奇怪的问题(prototype中的array难道也只是一个指针?) </code>
谢谢大家..
首先要明白是怎么实现继承的。。
1、构造函数有一个prototype
属性。
2、构造函数的每个实例都有一个__proto__
指向其构造函数的prototype属性。
3、当访问某对象自身不存在的属性,会通过__proto__
去其构造函数的prototype上寻找。
4、所以调用obj1.array
访问的是 Person.prototype.array
;调用obj2.array
访问的也是 Person.prototype.array
。
5、obj1
与obj2
都共用着这一个array
。
6、所以跟按值传递还是引用传递无关。本来各个实例都访问的是一个prototype
各实例没有保存一份对构造函数原型的拷贝····