一、原型链继承 在原型链继承方面,JavaScript与java、c#等语言类似,仅允许单父类继承。prototype继承的基本方式如下: 通过对象Child的prototype属性指向父对象Parent的实例,使Child对象实例能通过原型链访问到父对象构造所定义的属性、方法等。 构造通过原型链链接了父级对象,是否就意味着完成了对象的继承了呢?答案是否定的。如: 尽管child依然可以作为Child的实例使用,但此时已经丢失了实例child原有的对象构造信息。弥补该缺陷的方法如下: 如上代码片段“Child.prototype.constructor = Child”所示,通过显示地指定对象构造Child的原型,强制所有的Child对象实例的构造都为Child。 二、使用apply、call方法 由于JavaScript内置的Function对象的apply、call方法改变对象构造中“this”的上下文环境,使特定的对象实例具有对象构造中所定义的属性、方法。 使用apply、call继承,在实际开发中操作HTML页面上的DOM对象时尤为常用。如: 通过apply或call定义的ext方法,使ext方法内部的this上下文表示为DOM对象“<div id="extend">apply,call继承</div>”。 值得注意的是,当使用apply、call时,会直接执行对象构造所定义的代码段,如: 三、对象实例间的继承 JavaScript对象的多态性,允许实例动态地添加属性、方法。该特性造就了JavaScript中的另一种继承手法——对象实例间的继承。如: 如以上代码所示,在对象的实例间继承中,父对象Persong定义了“人”所具有的共同属性name、age,子对象nathena定义了自己的私有属性“sex”。函数inlineExtends的功能是,为子对象nathena复制父对象Person中定义的“人”所具有的共同属性。 其中特别需要注意的语句是“if (so[i])”,此句确保了子对象原有的成员不被父对象中同名的成员所覆盖,而违背面向对象中父子对象之间继承的原则——子对象可以覆盖、重载父对象的属性或方法,父对象仅能对子对象隐藏自己的属性或方法。
推荐整理分享实现JavaScript中继承的三种方式(javascript怎么用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js实现@功能,用js实现类的方法,javascript运用,js实现@功能,在javascript,在javascript,js类的实现,js类的实现,内容如对您有帮助,希望把文章链接给更多的朋友!
JavaScript 基于原型的对象(创建、调用) JavaScript中的对象有三种1,内部对象如Array,Boolean,Data,Math,Number,Object,RegExp,String对象等这些对象系统给我们提供了各自的属性与方法供调用。2
浅谈javascript 面向对象编程 感叹是为了缓解严肃的气氛并引出今天要讲的话题,javascript面向对象编程,接下来,我们围绕面向对象的几大关键字:封装,继承,多态,展开。封装
javascript 面向对象,实现namespace,class,继承,重载 由于组里项目大多的javascript,css等客户端工作是另一同事在负责,该同事又特忙无法重构,老大也就只是提建议并未立即实施重构。但是我前些日子也