JavaScript原型,原型鏈 超詳解

  1. 對象
    JS中一切皆是對象,每個對象都有一個__proto__屬性,該屬性也是一個對象(包含constructor屬性和__proto__屬性),那麼自身也必然存在一個__proto__,這樣逐級向上,就形成了一個鏈式,這個鏈式就被稱爲原型鏈
    當然它並不是永不停止地向上查找,__proto__的繼承的終極是Object。Object是所有對象的頂級對象。

  2. 函數
    函數除了具有__proto__之外,還有一個獨特的prototype 屬性,這個屬性也是一個對象,包含constructor屬性和__proto__屬性。

  3. constructor,__proto__和prototype

var Foo=function(){};
var f1=new Foo();
  • __proto__指向它的構造函數的原型對象
console.log(f1.__proto__===Foo.prototype);//true
  • constructor指向它的構造函數
console.log(f1.constructor===Foo);//true
  • Foo.prototype即原型對象,包含__proto__和constructor
console.log(Foo.prototype.constructor===Foo);//true
//這一點毫無疑問,Foo.prototype的構造函數是Foo
console.log(Foo.prototype.__proto__===Object.prototype);//true
//這是因爲Foo.prototype是普通對象,所以它的__proto__指向Object.prototype,
這一點在下文有更進一步的解釋

因此,就可以得出這一整個原型鏈爲
在這裏插入圖片描述
通過藉助一位大神的圖來整理一下以上說明:
在這裏插入圖片描述
針對這張圖,補充說明幾點:

  • JS中一切皆對象,但是對象分普通對象和函數對象。通過new Function()創建的都是函數對象,而下面的f1和f2本質上也是通過new Function()創建的。
var o1 = {}; 
var o2 = new Object();
var o3 = new f1();

function f1(){}; 
var f2 = function(){};
var f3 = new Function('str','console.log(str)');

console.log(typeof f1); //function 
console.log(typeof f2); //function 
console.log(typeof f3); //function   

console.log(typeof o1); //object 
console.log(typeof o2); //object 
console.log(typeof o3); //object
  • 構造器都是函數對象
    在這裏插入圖片描述
    所以,他們的__proto__也指向Function.prototype
console.log(Object.__proto__===Function.prototype);//true
console.log(Array.__proto__===Function.prototype);//true
//其他的幾個也都是
  • 原型對象是普通對象而不是函數對象,因爲它不是通過new Function()創建的(Function.prototype除外,但是,雖然它是函數對象,卻沒有prototype屬性,所以他的__proto__指向Object.prototype)(這也就解釋了爲什麼Foo.prototype.__proto__指向Object的原型對象)
console.log(typeof Object.prototype);//object
console.log(typeof Function.prototype);//function
console.log(Function.prototype.prototype);//undefined
console.log(Function.prototype.__proto__===Object.prototype);//true
//其他的幾個也都是
  • 原型鏈的終點是null,它是一個普通對象,但是它是空的,沒有__ptoto__和constructor屬性
console.log(Object.prototype.__proto__===null);//true
console.log(typeof null);//object
console.log(null.__ptoto__);//Uncaught TypeError: Cannot read property '__ptoto__' of null
console.log(null.constructor);//Uncaught TypeError: Cannot read property 'constructor' of null

參考文獻

  • [1] https://www.jianshu.com/p/dee9f8b14771
  • [2] https://www.jianshu.com/p/652991a67186
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章