JavaScript原型鏈中函數(shù)和對象的理解
__ proto__
最近在看高程4,原型鏈肯定是繞不過的,本瓜之前一直認為,只要記住這句話就可以了:
一個對象的隱式原型(__proto__)等于構(gòu)造這個對象的構(gòu)造函數(shù)的顯式原型(prototype)
確實,所有對象都符合這句真理,在控制臺打印一試便知:
const str = new String("123")
str.__proto__ === String.prototype // true
const arr = new Array(["123"])
arr.__proto__ === Array.prototype // true
const obj = new Object()
obj.__proto__ === Object.prototype // true
const bl = new Boolean(false)
bl.__proto__ === Boolean.prototype // true
......
const fn = function(){}
fn.__proto__ === Function.prototype // true
雖然我們平常都會像以下這樣寫居多,聲明方式不一樣,但結(jié)果不變:
const str = '123'
str.__proto__ === String.prototype // true
const arr = [123]
arr.__proto__ === Array.prototype // true
const obj = {}
obj.__proto__ === Object.prototype // true
const bl = false
bl.__proto__ === Boolean.prototype // true
......
const fn = new Function()
fn.__proto__ === Function.prototype // true
順著這個思路,那我們接著在構(gòu)造函數(shù)上,繼續(xù)用 __proto__ 尋找,可以得到:
String.__proto__=== Function.prototype // true Array.__proto__=== Function.prototype // true Boolean.__proto__=== Function.prototype // true Object.__proto__=== Function.prototype // true Function.__proto__=== Function.prototype // true
這些基本構(gòu)造函數(shù)(String、Array、Boolean、Object 等),都是用 Function 來構(gòu)造生成的??!
還能用 __proto__ 繼續(xù)向上找嗎? 不能了,因為結(jié)果會是一直重復下面這一行代碼:
Function.__proto__ === Function.prototype
所以,不管你怎樣通 __proto__ 隱式原型向上找,最終都只能找到 Function,而 Function 的隱式原型等于它的顯式原型;
prototype.__ proto__
但是這與我們所知不符呀,不是萬物皆對象嗎??
我們嘗試再用 __proto__ 向前探一步,發(fā)現(xiàn):
Function.__proto__.__proto__ === Object.prototype // true Function.__proto__ === Function.prototype // true Function.prototype.__proto__ === Object.prototype // true
Function 這個終極構(gòu)造函數(shù),通過查找顯式原型的隱式原型,竟然等于 Object 的顯式原型!
其實,其它構(gòu)造函數(shù)也一樣,都能找到 Object:
String.prototype.__proto__=== Object.prototype // true Array.prototype.__proto__=== Object.prototype // true Boolean.prototype.__proto__=== Object.prototype // true Object.prototype.__proto__=== Object.prototype // true
所有構(gòu)造函數(shù)的顯式原型的隱式原型 等于 Object 的顯式原型??!
理解
為什么要這樣設定呢??
為什么對象只用 .__proto__ 向上查找,最終只能找到 Function?
為什么構(gòu)造函數(shù)用 .prototype.__proto__ 向上查找,能找到 Object ?
這樣原型鏈查找不是有兩套邏輯嗎?
后來,本瓜歪理解:
【Function】就好像是創(chuàng)造萬物的上帝,它創(chuàng)造了:各種各樣的物質(zhì)【對象】,物質(zhì)又分化為:人【字符串】、魚【數(shù)組】、鳥【布爾】、獸【數(shù)值】、石頭【Date】、花草【正則】等等分類;
這些不同種類的物質(zhì),再一代一代延續(xù)(繁衍)下去。。。。。。
問:這些種類,它們子孫或后代們的特性【屬性】是來源于哪里呢??
1.可以從它們的祖先那里繼承而來,這一點沒毛病,生物 DNA 遺傳,龍生龍、鳳生鳳,老鼠兒子會打洞
let Mouse = function(){
this.makeAHole = true
}
let m1 = new Mouse()
m1.makeAHole // true
m1.__proto__.makeAHole === Mouse.prototype.makeAHole // true
2.或者還可以從【物質(zhì)】這個原始分類而來, 因為人魚鳥獸、花草樹木、石頭都還是屬于“物質(zhì)”,比如都有碳元素,就像字符串、數(shù)組、布爾、數(shù)值都是屬于“對象”,都有 toString 方法;
Object.prototype.carbon = true let p1 = 'man' p1.carbon // true p1.__proto__.__proto__.carbon === Object.prototype.carbon// true
對象 Object(物質(zhì))是由函數(shù) Function(上帝)創(chuàng)造的,沒毛病。
上帝(Function)也是一種物質(zhì)(Object),一切都是物質(zhì)(Object),物質(zhì)(Object)起源于大爆炸,起源于空(null),也沒毛病。
再來看這張經(jīng)典的圖:

按照咱們“理解”也畫一個:

哈哈哈,害行,這次就先理解到這吧,更多關于JavaScript原型鏈函數(shù)對象的資料請關注腳本之家其它相關文章!
相關文章
Flutter刷新組件RefreshIndicator自定義樣式demo
這篇文章主要介紹了Flutter刷新組件RefreshIndicator自定義樣式demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02
微信小程序 wx.request(接口調(diào)用方式)詳解及實例
這篇文章主要介紹了微信小程序 wx.request(接口調(diào)用方式)詳解及實例的相關資料,wx.request請求方式比較簡單,但是在使用的時候出現(xiàn)錯,這里就記錄下,需要的朋友可以參考下2016-11-11
js前端表單數(shù)據(jù)處理表單數(shù)據(jù)校驗
這篇文章主要為大家介紹了js前端表單數(shù)據(jù)處理表單數(shù)據(jù)校驗示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07
AntDesignPro使用electron構(gòu)建桌面應用示例詳解
這篇文章主要為大家介紹了AntDesignPro使用electron構(gòu)建桌面應用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10
JS實現(xiàn)將圖片URL轉(zhuǎn)base64示例詳解
這篇文章主要為大家介紹了JS實現(xiàn)將圖片URL轉(zhuǎn)base64示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03
5種 JavaScript 方式實現(xiàn)數(shù)組扁平化
這篇文章主要介紹5種 JavaScript 方式實現(xiàn)數(shù)組扁平化,雖說只有5種方法,但是核心只有一個就是遍歷數(shù)組arr,若arr[i]為數(shù)組則遞歸遍歷,直至arr[i]不為數(shù)組然后與之前的結(jié)果concat。 想具體了解的小伙伴那請看下面文章內(nèi)容吧2021-09-09

