使用prototype特性,可以很方便的在子类中继承父类的方法和属性。
下例中Vegetable视为父类,Celery视为子类。
Vegetable 拥有属性taste, 方法fun1
Celery 拥有属性 color, 方法fun2,如果再定义与Vegetable 中同名的属性或方法,则会覆盖父类Vegetable 中对应的属性和方法。
function Vegetable(){
this.taste='delicious';
this.fun1 = function(){
alert('Vegetable fun1 doing...');
}
}
function Celery(){
this.color = 'green';
this.taste = 'bad';
this.fun1 = function(){
alert('Celeryfun1 doing...');
}
this.fun2 = function(){
alert('Celery fun2 doing...');
}
}
Celery.prototype = new Vegetable();
var stick = new Celery();
var polymorphed = stick.taste;
alert(polymorphed);
alert(stick.color);
stick.fun1();
stick.fun2();
继承与覆盖:JavaScript原型链深入解读
本文详细解析了JavaScript中使用prototype特性实现子类继承父类的方法和属性的过程,包括属性覆盖与方法重写,并通过实例展示了如何在子类中调用父类的方法与属性。
490

被折叠的 条评论
为什么被折叠?



