Javascript原型鏈及instanceof原理詳解
instanceof:用來判斷實(shí)例是否是屬于某個(gè)對(duì)象,這個(gè)判斷依據(jù)是什么呢?
首先,了解一下javascript中的原型繼承的基礎(chǔ)知識(shí):
javascript中的對(duì)象都有一個(gè)__proto__屬性,這個(gè)是對(duì)象的隱式原型,指向該對(duì)象的父對(duì)象的原型(prototype)。顯式的原型對(duì)象使用prototype,但是Object.prototype.proto=null;
判斷某個(gè)對(duì)象a是否屬于某個(gè)類A的實(shí)例,可以通過搜索原型鏈。
實(shí)例對(duì)象屬性查找順序是:實(shí)例對(duì)象內(nèi)部---->構(gòu)造函數(shù)原型鏈---->實(shí)例對(duì)象父對(duì)象的原型鏈。
//繼承機(jī)制 function A(){ } A.prototype.name=’licui’; function B(){ } B.prototype = new A(); var a = new A(); var b = new B(); //b.name = ’hello’; console.log(’A:’,A); console.log(’B:’,B); console.log(’a:’,a); console.log(’b:’,b); console.log(’A.prototype’,A.prototype); console.log(’B.prototype’,B.prototype); console.log(’a._proto_’,a.__proto__); console.log(’b._proto_’,b.__proto__); console.log(’a instanceof A:’,a instanceof A); console.log(’a instanceof Object:’,a instanceof Object); console.log(’b instanceof B:’,b instanceof B); console.log(’b instanceof A:’,b instanceof A); console.log(’b instanceof Object:’,b instanceof Object);
執(zhí)行結(jié)果

constructor:是原型prototype上的屬性,實(shí)例上不具有該屬性。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 利用ajax+php實(shí)現(xiàn)商品價(jià)格計(jì)算2. HTML <!DOCTYPE> 標(biāo)簽3. JS圖片懶加載庫VueLazyLoad詳解4. Java實(shí)現(xiàn)的迷宮游戲5. Java利用TCP協(xié)議實(shí)現(xiàn)客戶端與服務(wù)器通信(附通信源碼)6. Java實(shí)現(xiàn)UDP通信過程實(shí)例分析【服務(wù)器端與客戶端】7. Vue基于iview table展示圖片實(shí)現(xiàn)點(diǎn)擊放大8. 使用AJAX(包含正則表達(dá)式)驗(yàn)證用戶登錄的步驟9. Java PreparedStatement用法詳解10. Python 解決火狐瀏覽器不彈出下載框直接下載的問題

網(wǎng)公網(wǎng)安備