Javascript原型鏈及instanceof原理詳解
instanceof:用來判斷實例是否是屬于某個對象,這個判斷依據(jù)是什么呢?
首先,了解一下javascript中的原型繼承的基礎(chǔ)知識:
javascript中的對象都有一個__proto__屬性,這個是對象的隱式原型,指向該對象的父對象的原型(prototype)。顯式的原型對象使用prototype,但是Object.prototype.proto=null;
判斷某個對象a是否屬于某個類A的實例,可以通過搜索原型鏈。
實例對象屬性查找順序是:實例對象內(nèi)部---->構(gòu)造函數(shù)原型鏈---->實例對象父對象的原型鏈。
//繼承機制 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上的屬性,實例上不具有該屬性。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 在JSP中使用formatNumber控制要顯示的小數(shù)位數(shù)方法2. UDDI FAQs3. ASP基礎(chǔ)入門第八篇(ASP內(nèi)建對象Application和Session)4. php過濾器使用詳解5. Javaweb工程運行報錯HTTP Status 404解決辦法6. 使用純HTML的通用數(shù)據(jù)管理和服務(wù)7. PHP循環(huán)與分支知識點梳理8. ASP中實現(xiàn)字符部位類似.NET里String對象的PadLeft和PadRight函數(shù)9. 解析原生JS getComputedStyle10. ElementUI下拉框選擇后不顯示值問題及解決
