原型鏈

原型鏈

構(gòu)造函數(shù)

 function Foo(name, age) {
  this.name = name
 }
 var f = new Foo('111')
 console.log(f.name)

Foo就是一個構(gòu)造函數(shù),我們使用 new 創(chuàng)建了一個實例對象 f

__proto__

所有的引用類型(object array function)都有一個__proto__ 屬性,屬性的值事一個普通對象

prototype

所有的函數(shù)都有一個prototype屬性,屬性值事一個普通對象。所有引用類型的__proto__屬性指向它的構(gòu)造函數(shù)的‘prototype’

 function fn() {}
 ?
 console.log(fn.__proto__)
 console.log(Function.prototype)

原型鏈和原型規(guī)則

當試圖得到一個對象的某個屬性事,如果這個對象本身沒有這個屬性,那么會去它的__proto__(構(gòu)造函數(shù)的的prototype)中尋找

 function Foo(name, age) {
  this.name = name
 }
 Foo.prototype.sayHello = function () {
  console.log('hello' + this.name)
 }
 ?
 var f = new Foo('james')
 f.sayHello()// hellojames
 f.toString()// __proto__.__proto__
 console.log(f.name)</pre>

原型鏈圖解:


1582708850597.png

instanceof

f instanceof Foo的判斷邏輯是:f的__proto__一層一層往上,能否找到對應(yīng)到Foo.prototype

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容