JS原型继承子类跟父类有相同属性但并不一定会覆盖
完成老师布置的作业时有疑惑,因为老师课堂讲的时候是这样说的。
// 如果父对象和子对象同时具有相同的属性
// 输出的时候,子对象的属性会覆盖父对象的属性进行输出
这是老师课堂上讲的对应的代码:
var person = function(){};
person.prototype.say=function(){
alert("天气挺好!");
}
person.prototype.gongzi=500;
var programmer=function(){};
programmer.prototype=new person();//只是将programmer更换成实例person的对象
programmer.prototype.wcd=function(){
alert("明天天气也不错!");
}
programmer.prototype.gongzi=1000;
var p = new programmer();//p是由programmer实例创建的
p.say();
p.wcd();
alert(p.gongzi);
调用父类方法、调用自己的方法都没有问题,因为继承了。
下面是作业题

因为在学面向对象的内容有点乱,当时我选的是CD,正确答案是BC。
上面的两个案例的代码很像,唯一不同的地方就父类的创建实例代码是在子类自有属性前面还是后面,如果是在子类前面,那么子类跟父类共有属性则会覆盖父类的。如果是在后面,刚子类只能继承父类的属性。
本文探讨了JavaScript中原型继承的机制,特别是当子类与父类存在相同属性时是否会发生覆盖的问题。通过具体示例代码说明,在不同情况下属性如何被处理,并解释了为何子类属性不一定总是覆盖父类属性。
829

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



