JS面向对象组件 -- 继承的其他方式(类式继承原型继承)

Posted 实之华之兹乃兼求,逆风兮,顺风兮,无阻我飞扬.

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS面向对象组件 -- 继承的其他方式(类式继承原型继承)相关的知识,希望对你有一定的参考价值。

继承的其他形式:
  •类式继承:利用构造函数(类)继承的方式
  •原型继承:借助原型来实现对象继承对象
 
类 : JS是没有类的概念的 , 把JS中的构造函数看做的类
要做属性和方法继承的时候,要分开继承。
function Aaa(){   //父类
    this.name = "小明";
}
Aaa.prototype.showName = function(){
    alert( this.name );
};

function Bbb(){   //子类

}
Bbb.prototype = new Aaa();   //类式继承
var b = new Bbb();
b.showName();
console.log(b);

而其中的

Bbb.prototype = new Aaa();是有这么一个图的。
技术分享
 
所以经常会有一个面试题目是,如何用一句话做到继承?答案就是这句话。
Bbb.prototype = new Aaa();但是这句话会有点问题的,不完善。

第一问题:

例如再在上面代码中加句
alert(b.constructor);  //弹出来的Aaa的构造函数。
故而需要将
Bbb.prototype = new Aaa();  修改成  Bbb.prototype = new Aaa();  Bbb.prototype.constructor = Bbb;  //修改指向问题
再弹出 b.constructor 就正确了。

第二个问题:
将上面的this.name = "小明"; 改成 this.name = [1,2,3];
再将 var b = new Bbb();b.showName(); 改成 var b = new Bbb();b1.name.push(4);var b2 = new Bbb();alert(b.name); 会发现结果是1,2,3,4。对象实例已经互相影响了。
看到上面那张图不难理解(都是Aaa中的name)。所以属性和方法要分开继承。解决方案如下:
function Aaa(){   //父类
    this.name = [1,2,3];
}    
Aaa.prototype.showName = function(){
    alert( this.name );
};

function Bbb(){   //子类
    
    Aaa.call(this);
    
}

var F = function(){};
F.prototype = Aaa.prototype;
Bbb.prototype = new F();
Bbb.prototype.constructor = Bbb; //修正指向问题

var b1 = new Bbb();
//b1.showName();
//alert( b1.name );
//alert( b1.constructor );
b1.name.push(4);

var b2 = new Bbb();

alert( b2.name );

F的作用就是 避免属性继承,而只是方法的继承





以上是关于JS面向对象组件 -- 继承的其他方式(类式继承原型继承)的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript 继承方式详解

javascript面向对象系列第三篇——实现继承的3种形式

JavaScript继承方式详解

js继承

昼猫笔记 JavaScript -- 面向对象(II)- 继承

JS继承以及继承的几种实现方式总结