js继承

js继承
js 继承-简书

原型链实现集继承

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();继承父类函数,实现函数复用

优点:不存在子类实例共享父类引用属性的问题
可传参
函数可复用
缺点: 父类构造器被实例化两次,浪费内存

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 原文链接 js的继承有6种方式,大致总结一下它们各自的优缺点,以及它们之间的关系。 1.原型链 js的继承机制不同...
    空_城__阅读 802评论 0 11
  • 前言 JS作为面向对象的弱类型语言,继承也是非常强大的特性之一,那么如何在JS实现继承呢? JS继承的实现方式 既...
    她是我的bug阅读 365评论 0 1
  • 博客内容:什么是面向对象为什么要面向对象面向对象编程的特性和原则理解对象属性创建对象继承 什么是面向对象 面向对象...
    _Dot912阅读 1,449评论 3 12
  • 我喜欢肚皮舞,被她的神秘、妩媚所吸引,觉得她展现了女性所有的美好。但是关于选择老师,我却有些担心。因为我看过太多健...
    喵喵de小来福阅读 200评论 0 0
  • 曾看到一篇反思当下快餐文化、物欲之楼栉比的新闻,文中提出了一个常见但是直击人心的问题:为何在科技发达、物质丰富的今...
    医路修行阅读 548评论 0 0