美文网首页让前端飞
JavaScript中的原型链和继承

JavaScript中的原型链和继承

作者: 强哥科技兴 | 来源:发表于2018-12-09 11:12 被阅读4次

理解原型链

在 JavaScript 的世界中,函数是一等公民。

上面这句话在很多地方都看到过。用我自己的话来理解就是:函数既当爹又当妈。“当爹”是因为我们用函数去处理各种“粗活累活”(各种工具函数、页面交互、业务逻辑等);“当妈”是因为函数还会“生孩子”(创建对象)。

在 JavaScript 的世界中,每一个对象都有一个隐藏的proto属性。这个属性指向生成这个对象的构造函数的原型(prototype)。事实上,所有函数都有一个原型。考虑如下例子:

所有实例对象都可以访问到相应原型对象里面的属性和方法。(理解原型链的关键)

实现继承

再看另外一个构造函数:

jsfiddle

虽然把 Human 的原型直接赋给 Coder 的原型可以让 Coder 的实例访问到 Human 原型上的属性和方法,但是如果想单独修改 Coder 原型的话会影响到 Human 原型上的值,这显然不是我们所期望的。

所以应该这样写:

从而实现了 JavaScript 最简单的原型链式继承。

不过这么写还是会有以下两个缺陷:

父类构造函数中的引用类型的属性(方法)是所有子类实例共享的,所以会出现改动一个实例的属性(或方法)会影响所有实例的属性(或方法)。

创建子类实例时,无法向父类构造函数传参。

所以需要在子类构造函数内调用一下父类构造函数,并把子类的this绑定上去:

最后:“相信有很多想学前端的小伙伴,今年年初我花了一个月整理了一份最适合2018年学习的web前端干货,从最基础的HTML+CSS+JS到移动端HTML5等都有整理,送给每一位前端小伙伴,53763,1707这里是小白聚集地,欢迎初学和进阶中的小伙伴。”

祝大家早日学有所成,拿到满意offer,快速升职加薪,走上人生巅峰。

相关文章

  • js原型、原型链、继承的理解

    一、原型、原型链 原型是Javascript中的继承的基础,JavaScript的继承主要依靠原型链来实现的。 原...

  • JavaScript 原型、原型链与原型继承

    原型,原型链与原型继承 用自己的方式理解原型,原型链和原型继承 javascript——原型与原型链 JavaSc...

  • javascript中的原型链与继承

    javascript中的原型链与继承javascipt中的原型链和继承机制是这门语言所特有的,但js中的原型机制也...

  • javascript碎片知识001

    javascript中的对象(原型,原型链) 什么是原型? 原型是JavaScript中的继承的基础,JavaSc...

  • JavaScript继承方式详解

    JavaScript实现继承的方式主要有两种: 原型链继承和借助构造函数继承 一、原型链继承 原型链继承的主要思想...

  • 【javascript】继承

    javascript只支持实现继承,而且继承主要是依靠原型链来实现的。 原型链 javascript将原型链作为实...

  • JS 中的一些概念问题

    Q:描述 JavaScript 中的继承和原型链,并举例子。 JavaScript 是基于原型的面向对象语言,并无...

  • es5的部分继承以及es6的class

    一、JavaScript常用的原型继承方式 原型链继承 2,构造函数继承(对象冒充继承) 3,组合继承(原型链继承...

  • javascript原型链及继承的理解

    javascript:void(null)# 原型链及继承的理解 定义函数 继承 继承构造函数 继承静态属性 继承原型链

  • JavaScript的六种继承方式

    JavaScript的几种继承方式 原型链继承 借助构造函数继承(经典继承) 组合继承:原型链 + 借用构造函数(...

网友评论

    本文标题:JavaScript中的原型链和继承

    本文链接:https://www.haomeiwen.com/subject/sdphhqtx.html