请教原型中定义成员的疑问?
发布于 12 年前 作者 hhuai 4863 次预览 最后一次回复是 12 年前 来自
有书《Node.js开发指南》这书的看一下162页,没书的,我给出代码和相关语句。
以下为书中原话: 尽量在构造函数内定义一般成员,尤其是对象或数组,因为用原型定义的成员是多个 实例共享的。
经我测试(下面是测试用例),就算在原型中定义的成员,并不是共享的,而是各有一份,这个怎么说?
function Foo () {
var innerVar = 'hello';
this.prop1 = 'BYVoid';
this.func1 = function() {
innerVar = '';
};
}
Foo.prototype.prop2 = 'Car';
Foo.prototype.func2 = function() {
console.log(this.prop2);
};
var foo1 = new Foo();
var foo2 = new Foo();
console.log(foo1.func1 == foo2.func1); //false
console.log(foo1.func2 == foo2.func2); //true
foo1.prop2 = 'Mobile';
foo1.func2(); //Mobile
foo2.func2(); //Car
7 回复
console.log(foo1.func2 == foo2.func2);输出true了这还不能证明么?呃, 你是想说
这句有问题么? 你可以试试
其实
foo2自身是没有prop2这个属性的, 但因为之前那一句foo1有了. js 解释器发现某个对象自身没这个属性时, 会往它的构造方法原型上找如果能找到, 这个就作为属性值.
所以实际上是
this.prop2这个表达式求值在两个对象上结果不一导致的.说得有道理。 还有一个疑问就是为什么foo1.prop2 不直接使用Foo原型中的prop2,而会去新生成一个prop2属性呢?
因为不能通过实例重写prototype的属性
只是屏蔽了prototype的prop2属性。你可以通过__proto__访问原型链上的prop2属性:
谢谢大家,终于明白了。
正解. 一个是原型的属性值,一个是对象自身的属性(动态添加的),造成了使用this求值的区别.
//假想的new操作符 function New (f) { var n = { ‘proto’: f.prototype }; return function () { f.apply(n, arguments); return n; }; } // 顺序:先使用prototype创建对象,再使用构造函数处理创建的对象