美文网首页
图解JavaScript对象原型与原型链

图解JavaScript对象原型与原型链

作者: 帅华君 | 来源:发表于2019-07-11 18:23 被阅读0次
图解JavaScript对象原型与原型链

使用颜色、形状可视化Javascript中抽象的原型链概念:

橙黄色实心代表函数,函数是可执行的对象;

橘红色圈圈代表prototype属性,且总是存在于函数对象中;

蓝紫色带箭头线段代表原型链的走向;

蓝绿色实心代表普通对象

圈圈+实心组合形式的含义:

橘红色圈圈+黄色实心代表prototype属性为函数对象;

橘黄色圈圈+蓝绿色实心代表prototype属性为普通对象;

图中,prototype属性就是可以被继承的原型,原型可以是函数,也可以是普通对象,没有原型的对象为数不多,Object.prototype就是其中之一,如图中右侧所示Object.prototype原型链箭头指向null,这里是所有原型链的终点,也意味着原型链到此结束,满足:

Object.prototype.__proto__ ===null// true

我们熟悉的JSON和Math都是普通对象,而不是构造函数,因此它们两个的原型都是Object.prototype,满足:

JSON.__proto__ ===Object.prototype// trueMath.__proto__ ===Object.prototype// true

我们使用对象直接量{}创建的对象,和使用不常用的new Object()写法所创建的对象的原型也都是Object.prototype。

使用Object.create()创建的对象的原型却不一定是Object.prototype,这取决于传入的第一个参数,因为第一个参数是用来指定我们想要创建的对象的原型,除非第一个参数传入Object.prototype``,显然这么做对Object.create()```这个方法属实大材小用了。

许多常见的内置构造函数,比如Date和RegExp等等,它们是函数,因为可以和new关键字一起使用而创建新的对象,所以被称作构造函数,不过它们也是对象,特殊的可以执行对象。

几乎所有函数,不论是JS内置构造函数,还是我们创建的函数,它们的原型都是Function.prototype,满足:

Date.__proto__ ===Function.prototype// trueArray.__proto__ ===Function.prototype// truefunctionmyFunc(){}myFunc.__proto__ ===Function.prototype// true

内置构造函数Function的原型和其它函数一样,也是Function.prototype,这就像是自己的原型就是自己身上的一个部分,妙。满足:

Function.__proto__ ===Function.prototype// true

几乎所有内置的构造函数的prototype属性都是普通对象,但构造函数Function除外,因为Function.prototype的特殊之处在于,它是可执行的函数对象,不是普通对象:

typeofFunction.prototype// "function"

让我觉得JS在强行自圆其说的一点是,虽然Function.prototype也是函数,但是它的原型竟是Object.prototype。

Function.prototype.__proto__ ===Object.prototype// true

为什么Function.prototype作为一个函数,它的原型不应该是Function.prototype自身吗,规范就是这么规定的,所以说Function属于比较个性的一位,它的特殊总结来说分为以下亮点:

Function的原型就是Function.prototype。但是比如说Date.__proto__ === Date.prototype就不成立;

Date、Array和Function等等是都是函数,且它们的原型也是函数Function.prototype,但是Function.prototype的原型却是Object.prototype,而不是它自身。

和Function.prototype一样特殊的就是Object.prototype了,因为Object.prototype虽然是对象,但是它的原型不是它自身,而是null。

并不是所有函数的原型都是Function.prototype,因为Function.prototype自身也是函数;

并不是所有对象的原型都是Object.prototype,因为Object.prototype自身也是对象;

我只能告诉你,Function.prototype是一个特殊的函数;

我只能告诉你,Object.prototype是一个特殊的对象。

这世界,许多事不能仅靠理性就能讲明白,就像男人永远别指望和女人理性的讲道理,懂得太多的人被心眼绊倒。我所知道的太少太少,我们知道的都太少了,事情背后有太多不知道的事情了,事情的事情的背后又有不知道的事情。

绝要停止探寻真理的步伐,哪怕一切徒劳,人总要有事可做。

null是一切吖。

相关文章

  • 原型、原型链

    (什么是原型、原型链?有什么作用) JavaScirpt深入之从原型到原型链 图解 Javascript 原型链 ...

  • 在nodejs中面向对象:Bearcat

    JS中的面向对象 最最最开始,我们先来说说JS中的面向对象。 原型链 参考文章:图解Javascript原型链 J...

  • 图解JavaScript对象原型与原型链

    使用颜色、形状可视化Javascript中抽象的原型链概念: 橙黄色实心代表函数,函数是可执行的对象; 橘红色圈圈...

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

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

  • 原型与原型链

    JavaScript仍然大量地使用了对象,为了保证对象之间的联系,JavaScript引入了原型与原型链的概念。 ...

  • javascript碎片知识001

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

  • ES6 原型和原型链相关面试题

    javascript原型与原型链 每个函数都有一个prototype属性,被称为显示原型 每个实例对象都会有_ _...

  • JavaScript面试考点之原型及原型链

    1、JavaScript原型及原型链 1)原型 JavaScript是一种基于原型的语言,即每一个对象拥有一个原型...

  • JS原型链

    javaScript原型链 JavaScript所有对象都有原型,当对象有属性或方法调用的时候,对象就会从自身查找...

  • 关于JS中的原型和原型链

    目录 关于js 对象和原型 原型链 基于原型链的继承 参考资料ECMAScript 6 入门JavaScript原...

网友评论

      本文标题:图解JavaScript对象原型与原型链

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