The top of the object graph is formed to maintain as much consistency with the expectations set elsewhere in the spec.
Necessarily, there comes a point where normal object linkages cannot be used because you "run out of objects".
A basic understanding of JavaScript leads us to expect the [[Prototype]]
of Object
to be the prototype property of the function used to create the Object
function-object.
We expect Function
s to be created using the Function
function-object, so...
Object.__proto__ === Function.prototype
Because we are at the top of the object graph and want to maintain consistency of expected behavior we configure the [[Prototype]]
of Function
to be Function.prototype
.
Function.__proto__ === Function.prototype
Thus ensuring Function instanceof Function === true
.
We can show that Function.prototype
is a special function-object because:
Function.prototype.prototype === undefined
...and every user-defined function (other than fat-arrows) has an object on its prototype property.
Because of all the above:
Object.__proto__ === Function.__proto__
This may might look odd, but as previously noted, at the top of the object graph we have a limited set of candidate objects to point to.
TC-39 now needed to identify what the [[Prototype]]
of the [[Prototype]]
of Object
was.
Per the above we know that the [[Prototype]]
of Object
is Function.prototype
.
In some sense we are now above Function.prototype
in the object graph, so a special Object
instance (the "prototype object") was chosen to be this value.
This means that the top of every prototype chain can be conveniently tied up with Object.prototype
.
This of course, also meets the desireable requirement that everything "is an object".
Object.__proto__.__proto__ === Object.prototype
At this point we need to complete the object graph, so we set the [[Prototype]]
of Object.prototype
to be null
.
Object.__proto__.__proto__.__proto__ === null
Object.__proto__ === Function.prototype
...Object is a function.typeof Object === "function"
– Anticipate__proto__
was added to ECMAScript 6. – AnticipateFunction.prototype
appears to be an empty function is that many of the prototypes of the built-in constructors are actually an instance of the object they construct. For example,Array.isArray(Array.prototype); // true
(Or maybe not quite an instance, but they have some relationship back to the constructor.) – AnticipateFunction.__proto__===Function.prototype
– CalycleObject.__proto__ === Function.prototype
being true andObject.__proto__.__proto__ === Object.prototype
being true cleared this up for me. I've always assumedObject
andFunction
were at the same hierarchy level, and thatObject
's prototype wasObject.prototype
. If you wanted to add some version of your comment as an answer I'm happy to mark it as best. – Izzo