JavaScript原型(prototype)及原型链(prototype chaining)的问题

阅读《JavaScript高级程序设计(第2版)》第6章的学习笔记。原型在引用类型中会有问题:

function SuperType(){

}

SuperType.prototype.color = ['red','blue','green'];



var instance1 = new SuperType();

instance1.color.push('black');

var instance2 = new SuperType();

console.log(instance2.color);

引用类型的原型(prototype)属性中会被所有实例共享的问题。下面继承中的原型链(prototype chaining)也是同样的问题:

function SuperType(){

	this.color = ['red','blue','green'];	

}



function SubType(){

}

SubType.prototype = new SuperType();



var instance1 = new SubType();

instance1.color.push('black');



var instance2 = new SubType();

console.log(instance2.color);

子类(SubType)的实例的属性实际上是指向了在 prototype 中的属性。这是因为超类(SuperType)的实例赋给了子类的原型,这样超类的属性变成了子类的原型中的属性。

你可能感兴趣的:(JavaScript)