原型链实现集继承
function father(){
this.val=1;
this.arr=[1]
}
function son(){}
son.prototype=new father
var son1=new son()
var son2=new son()
son1.val=2
son2.varl //1
son1.arr.push(2)
son2.arr //[1,2]
上面的代码实现原型链继承最重要的son.prototype=new father
原型链继承的优点和缺点:
优点:实现容易,操作简单
缺点:来自原型对象的引用属性是所有实例都共享的,
另一个缺点就是 无法通过子类构造器向父类传参
构造器函数实现继承
function father(val){
this.val=val
this.arr=arr;
this.fun=function(){}
}
function son (val){
father.call(this,val)
}
var son1=new son(1)
var son2=new son(2)
核心:借用父类的构造器来增强子类的实例,相当于把父类的实例属性复制一给子类装上(完全没有用到原型)
优点:解决了子类共享父类引用书属性的问题
子类构造器能够向父类构造器传参
缺点:无法实现函数的复用,每个子类实例都有一个自己的方法,太多了影响性能
组合发方式实现继承
function super(){
this.val=2
this.arr=[2]
}
super.prototype.fun=function(){}
function sub(){
father.call(this)
}
sub.prototype=new super
var sub1=new sub()
var sub2=new sub()
核心:把实例函数都放在原型对象上,以实现函数复用。同时还要保留借用构造函数方式的优点,通过Super.call(this);继承父类的基本属性和引用属性并保留能传参的优点;通过Sub.prototype = new Super();继承父类函数,实现函数复用
优点:不存在子类实例共享父类引用属性的问题
可传参
函数可复用
缺点: 父类构造器被实例化两次,浪费内存