Js继承

一、对象冒充

1.

function ClassA(name){

   this.name = name;

}

ClassA.prototype.getName = function(){

   return this.name;

}

function ClassB(name){

    this.method1 = ClassA;

    this.method1(name);

    delete ClassB.prototype.method1;

}

2.call

function ClassA(name){

   this.name = name;

}

ClassA.prototype.getName = function(){

   return this.name;

}

function ClassB(name){

   ClassA.call(this,name);

}

可支持多继承

3.apply

function ClassA(name){

   this.name = name;

}

ClassA.prototype.getName = function(){

   return this.name;

}

function ClassB(name){

   ClassA.apply(this,new Array(name));

}

二、原型链

 

function ClassA(){

}

ClassA.prototype.name = "张三";

ClassA.prototype.getName = function(){

   return this.name;

}

ClassB.prototype = new ClassA();

ClassB.prototype.name = "王五";

不支持多继承

三、对象冒充+原型链

function ClassA(name){

   this.name = name;

}

ClassA.prototype.getName = function(){

    return this.name;

}

function ClassB(name){

   ClassB.call(this,name);

}

ClassB.prototype = new ClassA();

ClassB.prototype.age = "10";

Js继承,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。