欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript原型鏈中函數(shù)和對象的理解

 更新時間:2022年06月15日 09:33:22   作者:掘金安東尼  
這篇文章主要為大家介紹了JavaScript原型鏈中函數(shù)和對象的理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

__ proto__

最近在看高程4,原型鏈肯定是繞不過的,本瓜之前一直認(rèn)為,只要記住這句話就可以了:

一個對象的隱式原型(__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é)果會是一直重復(fù)下面這一行代碼:

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 的顯式原型?。?/strong>

理解

為什么要這樣設(shè)定呢??

為什么對象只用 .__proto__ 向上查找,最終只能找到 Function?

為什么構(gòu)造函數(shù)用 .prototype.__proto__ 向上查找,能找到 Object ?

這樣原型鏈查找不是有兩套邏輯嗎?

后來,本瓜歪理解:

【Function】就好像是創(chuàng)造萬物的上帝,它創(chuàng)造了:各種各樣的物質(zhì)【對象】,物質(zhì)又分化為:人【字符串】、魚【數(shù)組】、鳥【布爾】、獸【數(shù)值】、石頭【Date】、花草【正則】等等分類;

這些不同種類的物質(zhì),再一代一代延續(xù)(繁衍)下去。。。。。。

問:這些種類,它們子孫或后代們的特性【屬性】是來源于哪里呢??

1.可以從它們的祖先那里繼承而來,這一點(diǎn)沒毛病,生物 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)典的圖:

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

哈哈哈,害行,這次就先理解到這吧,更多關(guān)于JavaScript原型鏈函數(shù)對象的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • JavaScript 反射學(xué)習(xí)技巧

    JavaScript 反射學(xué)習(xí)技巧

    這篇文章主要給大家分享的是JavaScript 的反射學(xué)習(xí)技巧,主要是區(qū)別在于所有的函數(shù)對象屬性過于復(fù)雜,而且額外增加可能會導(dǎo)致程序行為不合理,所以擴(kuò)展 Reflect 函數(shù)來專門對函數(shù)對象處理調(diào)用方法,構(gòu)造對象,獲取或者設(shè)置屬性等相關(guān)操作。下面一起進(jìn)入文章內(nèi)容吧
    2021-10-10
  • javascript對象3個屬性特征

    javascript對象3個屬性特征

    這篇文章主要介紹了javascript對象3個屬性特征,writable可寫、enumerable可枚舉、configurable可配置,下面來看看文章的詳細(xì)內(nèi)容吧
    2021-11-11
  • 微信小程序聯(lián)網(wǎng)請求的輪播圖

    微信小程序聯(lián)網(wǎng)請求的輪播圖

    這篇文章主要介紹了微信小程序聯(lián)網(wǎng)請求的輪播圖的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • 微信小程序網(wǎng)絡(luò)請求wx.request詳解及實例

    微信小程序網(wǎng)絡(luò)請求wx.request詳解及實例

    這篇文章主要介紹了微信小程序網(wǎng)絡(luò)請求wx.request詳解及實例的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • 前端使用xlsx庫導(dǎo)出帶有樣式的excel文件

    前端使用xlsx庫導(dǎo)出帶有樣式的excel文件

    這篇文章主要為大家介紹了前端使用xlsx庫導(dǎo)出帶有樣式的excel文件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • 微信小程序 MINA文件結(jié)構(gòu)

    微信小程序 MINA文件結(jié)構(gòu)

    這篇文章主要介紹了微信小程序 MINA文件結(jié)構(gòu)的相關(guān)資料,這里詳細(xì)介紹了微信小程序的文件目錄及文件作用,需要的朋友可以參考下
    2016-10-10
  • JS前端canvas交互實現(xiàn)拖拽旋轉(zhuǎn)及縮放示例

    JS前端canvas交互實現(xiàn)拖拽旋轉(zhuǎn)及縮放示例

    這篇文章主要為大家介紹了JS前端canvas交互實現(xiàn)拖拽旋轉(zhuǎn)及縮放示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • 前端框架arco?table源碼遇到的問題解析

    前端框架arco?table源碼遇到的問題解析

    這篇文章主要為大家介紹了前端框架arco?table源碼遇到的問題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • JavaScript中的宏任務(wù)和微任務(wù)詳情

    JavaScript中的宏任務(wù)和微任務(wù)詳情

    這篇文章主要介紹了JavaScript中的宏任務(wù)和微任務(wù),下面文章圍繞JavaScript宏任務(wù)和微任務(wù)相關(guān)資料展開詳細(xì)內(nèi)容,需要的朋友可以參考一下,希望對大家有所幫助
    2021-11-11
  • 新聞內(nèi)頁-JS分頁

    新聞內(nèi)頁-JS分頁

    新聞內(nèi)頁-JS分頁...
    2006-06-06

最新評論