您好,登錄后才能下訂單哦!
這篇“es6原型鏈是什么及怎么實現”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“es6原型鏈是什么及怎么實現”文章吧。
原型鏈,簡單理解就是原型組成的鏈。當訪問一個對象的某個屬性時,會先在這個對象本身屬性上查找,如果沒有找到,則會去它的__proto__隱式原型上查找,即它的構造函數的prototype,如果還沒有找到就會再在構造函數的prototype的__proto__中查找,這樣一層一層向上查找就會形成一個鏈式結構,被稱為原型鏈。
在JS中,每個函數在被創建的時候就會有一個 prototype屬性,這個屬性是一個指針,指向一個對象,而這個對象就是這個函數的原型對象(也就是原型),它是用來共享所有實例的屬性和方法的地方,所以
原型其實就是函數的伴生體
(與生俱來的)
var a = [1, 2, 3, 4, 5];
a.__proto__ === Array.prototype; // true
原型鏈,簡單理解就是原型組成的鏈。當訪問一個對象的某個屬性時,會先在這個對象本身屬性上查找,如果沒有找到,則會去它的__proto__隱式原型上查找,即它的構造函數的prototype,如果還沒有找到就會再在構造函數的prototype的__proto__中查找,這樣一層一層向上查找就會形成一個鏈式結構,我們稱為
原型鏈
。
創建一個構造函數:
function Person (name) {
this.name = name
}
var cheng = new Person('Cheng');
var lin = new Person('Lin');
打印cheng和lin,可以看到兩個對象中都分別存在一個__proto__屬性
然后發現
console.log(cheng.__proto__ === lin.__proto__); // true
那么實例對象的這個__proto__屬性到底是什么玩意?
console.log(cheng.__proto__ === Person.prototype); // true
console.log(lin.__proto__ === Person.prototype); // true
小結:實例對象有一個不可枚舉的屬性 proto,這個屬性是一個指針,指向了其構造函數的prototype也就是原型對象,實例可以通過 proto 訪問到構造函數的原型上的方法
簡單來說,實例對象的 __proto__ 指向構造函數的 prototype
那么,這個構造函數的原型是什么呢?
打印Person.prototype,可以看到也存在一個__proto__屬性
console.log(Person.prototype.__proto__ === Object.prototype)
小結:函數的原型本質就是一個普通對象,所以他是來自Object的實例,因此,原型對象的 proto 屬性指向Object.prototype。
再往下找Object.prototype的__proto__是指向哪里呢?
最后發現是指向null
小結:Javascript中任意數據都能沿著自己的原型鏈最終找到Object.prototype
以上就是關于“es6原型鏈是什么及怎么實現”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。