图解JavaScript对象原型与原型链


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

  1. 橙黄色实心表明函数,函数是可执行的对象;
  2. 橘红色圈圈表明prototype属性,且老是存在于函数对象中;
  3. 蓝紫色带箭头线段表明原型链的走向;
  4. 蓝绿色实心表明普通对象

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

  1. 橘红色圈圈+黄色实心表明prototype属性为函数对象;
  2. 橘黄色圈圈+蓝绿色实心表明prototype属性为普通对象;

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

Object.prototype.__proto__ === null // true
复制代码

咱们熟悉的JSONMath都是普通对象,而不是构造函数,所以它们两个的原型都是Object.prototype,知足:ui

JSON.__proto__ === Object.prototype // true
Math.__proto__ === Object.prototype // true
复制代码

咱们使用对象直接量{}建立的对象,和使用不经常使用的new Object()写法所建立的对象的原型也都是Object.prototypespa

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

许多常见的内置构造函数,好比DateRegExp等等,它们是函数,由于能够和new关键字一块儿使用而建立新的对象,因此被称做构造函数,不过它们也是对象,特殊的能够执行对象。code

几乎全部函数,不管是JS内置构造函数,仍是咱们建立的函数,它们的原型都是Function.prototype,知足:cdn

Date.__proto__ === Function.prototype // true
Array.__proto__ === Function.prototype // true

function myFunc(){}
myFunc.__proto__ === Function.prototype // true
复制代码

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

Function.__proto__ === Function.prototype // true
复制代码

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

typeof Function.prototype // "function"
复制代码

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

Function.prototype.__proto__ === Object.prototype // true
复制代码

为何Function.prototype做为一个函数,它的原型不该该是Function.prototype自身吗,规范就是这么规定的,因此说Function属于比较个性的一位,它的特殊总结来讲分为如下两点:

  1. Function的原型就是Function.prototype。可是好比说Date.__proto__ === Date.prototype就不成立;
  2. DateArrayFunction等等都是函数,且它们的原型也是函数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是一切吖。



原文连接:shuaihua.cc/article/jav…

原创做者:帅华君

相关文章
相关标签/搜索