有书《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 回复
呃, 你是想说
foo1.prop2 = 'Mobile';
这句有问题么? 你可以试试
console.log(foo1); // { prop1: 'BYVoid', func1: [Function], prop2: 'Mobile' }
console.log(foo2); // { prop1: 'BYVoid', func1: [Function] } 没有 prop2!
其实 foo2
自身是没有 prop2
这个属性的, 但因为之前那一句 foo1
有了. js 解释器发现某个对象自身没这个属性时, 会往它的构造方法原型上找
console.log(foo2.constructor.prototype); // { prop2: 'Car', func2: [Function] }
如果能找到, 这个就作为属性值.
所以实际上是 this.prop2
这个表达式求值在两个对象上结果不一导致的.