理解Javascript_07_理解instanceof實(shí)現(xiàn)原理
更新時間:2010年10月15日 23:49:36 作者:
在《Javascript類型檢測》一文中講到了用instanceof來用做檢測類型,讓我們來回顧一下

那么instanceof的這種行為到底是如何實(shí)現(xiàn)的呢,現(xiàn)在讓我們揭開instanceof背后的迷霧。
instanceof原理
照慣例,我們先來看一段代碼:
復(fù)制代碼 代碼如下:
function Cat(){}
Cat.prototype = {}
function Dog(){}
Dog.prototype ={}
var dog1 = new Dog();
alert(dog1 instanceof Dog);//true
alert(dog1 instanceof Object);//true
Dog.prototype = Cat.prototype;
alert(dog1 instanceof Dog);//false
alert(dog1 instanceof Cat);//false
alert(dog1 instanceof Object);//true;
var dog2= new Dog();
alert(dog2 instanceof Dog);//true
alert(dog2 instanceof Cat);//true
alert(dog2 instanceof Object);//true
Dog.prototype = null;
var dog3 = new Dog();
alert(dog3 instanceof Cat);//false
alert(dog3 instanceof Object);//true
alert(dog3 instanceof Dog);//error
讓我們畫一張內(nèi)存圖來分析一下:

內(nèi)存圖比較復(fù)雜,解釋一下:
程序本身是一個動態(tài)的概念,隨著程序的執(zhí)行,Dog.prototype會不斷的改變。但是為了方便,我只畫了一張圖來表達(dá)這三次prototype引用的改變。在堆中,右邊是函數(shù)對象的內(nèi)存表示,中間的是函數(shù)對象的prototype屬性的指向,左邊的是函數(shù)對象創(chuàng)建的對象實(shí)例。其中函數(shù)對象指向prototype屬性的指針上寫了dog1,dog2,dog3分別對應(yīng)Dog.prototype的三次引用改變。它們和棧中的dog1,dog2,dog3也有對應(yīng)的關(guān)系。(注:關(guān)于函數(shù)對象將在后續(xù)博文中講解)
來有一點(diǎn)要注意,就是dog3中函數(shù)對象的prototype屬性為null,則函數(shù)對象實(shí)例dog3的內(nèi)部[[prototype]]屬性將指向Object.prototype,這一點(diǎn)在《理解Javascript_06_理解對象的創(chuàng)建過程》已經(jīng)講解過了。
結(jié)論
根據(jù)代碼運(yùn)行結(jié)果和內(nèi)存結(jié)構(gòu),推導(dǎo)出結(jié)論:
instanceof 檢測一個對象A是不是另一個對象B的實(shí)例的原理是:查看對象B的prototype指向的對象是否在對象A的[[prototype]]鏈上。如果在,則返回true,如果不在則返回false。不過有一個特殊的情況,當(dāng)對象B的prototype為null將會報(bào)錯(類似于空指針異常)。
這里推薦一篇文章,來自于歲月如歌,也是關(guān)于instanceof原理的,角度不同,但有異曲同工之妙。
相關(guān)文章
JavaScript實(shí)現(xiàn)班級抽簽小程序
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)班級抽簽小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-05-05
JS實(shí)現(xiàn)HTML標(biāo)簽轉(zhuǎn)義及反轉(zhuǎn)義
本文主要介紹了JS實(shí)現(xiàn)HTML標(biāo)簽轉(zhuǎn)義及反轉(zhuǎn)義的方法。具有一定的參考價值,下面跟著小編一起來看下吧2017-01-01
uniapp開發(fā)小程序?qū)崿F(xiàn)滑動頁面控制元素的顯示和隱藏效果
這篇文章主要介紹了uniapp開發(fā)小程序?qū)崿F(xiàn)滑動頁面控制元素的顯示和隱藏效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12
微信小程序swiper使用網(wǎng)絡(luò)圖片不顯示問題解決
這篇文章主要介紹了微信小程序swiper使用網(wǎng)絡(luò)圖片不顯示問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-12-12
解決input輸入框僅支持輸入數(shù)字及兩位小數(shù)點(diǎn)的限制
這篇文章主要為大家介紹了解決input輸入框僅支持輸入數(shù)字及兩位小數(shù)點(diǎn)的限制技巧示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11

