參考《你不知道的JavaScript(上卷)》,按照自己理解做的物件關聯關係圖解,不保真。
細節重申
- 物件透過原型鏈(__proto__)查詢屬性,一直到找到為止;
- new 的主要作用是建立新物件,其__proto__指向函式的 prototype,以及關聯this到新物件;
- Object.create 建立新物件,並將其__proto__指向舊物件。
依圖校驗
function Foo(){}
a = new Foo()
b = new Foo()
c = Object.create(Foo)
d = {}
Foo.__proto__ === Foo.prototype // false
Foo.prototype === Foo.__proto__ // false
Foo.prototype === a.__proto__ // true
Foo.prototype === b.__proto__ // true
a.constructor === Foo // true
a.constructor === Foo.prototype // false ,透過原型鏈找到constructor
c.prototype === Foo.prototype // true ,透過原型鏈找到prototype
c.__proto__ === Foo // true
Foo.__proto__ === Function.prototype // true
Foo.__proto__ === Function.__proto__ // true
Foo.__proto__.constructor === Function // true
Function.prototype === Object.__proto__ // true
Function.prototype === Object.prototype // false
Object.prototype === d.__proto__ // true
Object.prototype.__proto__ === null // true