圖文詳解JavaScript的原型對(duì)象及原型鏈
對(duì)于新人來(lái)說(shuō),JavaScript的原型是一個(gè)很讓人頭疼的事情,一來(lái)prototype容易與__proto__混淆,二來(lái)它們之間的各種指向?qū)嵲谟行?fù)雜,其實(shí)市面上已經(jīng)有非常多的文章在嘗試說(shuō)清楚,有一張所謂很經(jīng)典的圖,上面畫(huà)了各種線條,一會(huì)連接這個(gè)一會(huì)連接那個(gè),說(shuō)實(shí)話我自己看得就非常頭暈,更談不上完全理解了。所以我自己也想嘗試一下,看看能不能把原型中的重要知識(shí)點(diǎn)拆分出來(lái),用最簡(jiǎn)單的圖表形式說(shuō)清楚。
我們知道原型是一個(gè)對(duì)象,其他對(duì)象可以通過(guò)它實(shí)現(xiàn)屬性繼承。但是尼瑪除了prototype,又有一個(gè)__proto__是用來(lái)干嘛的?長(zhǎng)那么像,讓人怎么區(qū)分呢?它們都指向誰(shuí),那么混亂怎么記???原型鏈又是什么鬼?相信不少初學(xué)者甚至有一定經(jīng)驗(yàn)的老鳥(niǎo)都不一定能完全說(shuō)清楚,下面用三張簡(jiǎn)單的圖,配合一些示例代碼來(lái)理解一下。
一、prototype和__proto__的區(qū)別
var a = {};
console.log(a.prototype); //undefined
console.log(a.__proto__); //Object {}
var b = function(){}
console.log(b.prototype); //b {}
console.log(b.__proto__); //function() {}

/*1、字面量方式*/
var a = {};
console.log(a.__proto__); //Object {}
console.log(a.__proto__ === a.constructor.prototype); //true
/*2、構(gòu)造器方式*/
var A = function(){};
var a = new A();
console.log(a.__proto__); //A {}
console.log(a.__proto__ === a.constructor.prototype); //true
/*3、Object.create()方式*/
var a1 = {a:1}
var a2 = Object.create(a1);
console.log(a2.__proto__); //Object {a: 1}
console.log(a.__proto__ === a.constructor.prototype); //false(此處即為圖1中的例外情況)

var A = function(){};
var a = new A();
console.log(a.__proto__); //A {}(即構(gòu)造器function A 的原型對(duì)象)
console.log(a.__proto__.__proto__); //Object {}(即構(gòu)造器function Object 的原型對(duì)象)
console.log(a.__proto__.__proto__.__proto__); //null
以上就是本文的全部?jī)?nèi)容了,本文用三張圖解釋了JavaScript的原型對(duì)象與原型鏈,希望對(duì)大家學(xué)習(xí)JavaScript的時(shí)候有所幫助。
- 一文秒懂JavaScript構(gòu)造函數(shù)、實(shí)例、原型對(duì)象以及原型鏈
- 詳解js中的原型,原型對(duì)象,原型鏈
- js 原型對(duì)象和原型鏈理解
- 淺談JS原型對(duì)象和原型鏈
- JS原型對(duì)象操作實(shí)例分析
- JavaScript原型對(duì)象原理與應(yīng)用分析
- JavaScript原型對(duì)象、構(gòu)造函數(shù)和實(shí)例對(duì)象功能與用法詳解
- js使用原型對(duì)象(prototype)需要注意的地方
- javascript構(gòu)造函數(shù)以及原型對(duì)象的理解
- 深入理解javascript構(gòu)造函數(shù)和原型對(duì)象
- 全面解析js中的原型,原型對(duì)象,原型鏈
相關(guān)文章
微信小程序中實(shí)現(xiàn)雙向綁定的實(shí)戰(zhàn)過(guò)程
最近在小程序的開(kāi)發(fā)過(guò)程中,需要用到雙向綁定,遇到報(bào)錯(cuò)才知道微信本身是不支持對(duì)象雙向綁定的,折騰一番找到解決方案,下面這篇文章主要給大家介紹了關(guān)于微信小程序中實(shí)現(xiàn)雙向綁定的相關(guān)資料,需要的朋友可以參考下2023-01-01
javascript實(shí)現(xiàn)的動(dòng)態(tài)文字變換
javascript實(shí)現(xiàn)的動(dòng)態(tài)文字變換...2007-07-07
基于JavaScript實(shí)現(xiàn)抽獎(jiǎng)系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)抽獎(jiǎng)系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
JavaScript實(shí)現(xiàn)隨機(jī)點(diǎn)名程序
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)隨機(jī)點(diǎn)名程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03
JavaScript實(shí)現(xiàn)復(fù)制文章自動(dòng)添加版權(quán)
自己辛辛苦苦寫(xiě)的文章,輕易就被別人復(fù)制-粘貼去了,是不是很傷心呢?小編今天給大家整理了兩個(gè)方法,讓別人復(fù)制自己的文章時(shí),自動(dòng)在文章的結(jié)尾添加自己的版權(quán)信息。2016-08-08
在layui中使用form表單監(jiān)聽(tīng)ajax異步驗(yàn)證注冊(cè)的實(shí)例
今天小編就為大家分享一篇在layui中使用form表單監(jiān)聽(tīng)ajax異步驗(yàn)證注冊(cè)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
JavaScript中將字符串轉(zhuǎn)換為浮點(diǎn)數(shù)的技巧
在JavaScript中,parseFloat是一個(gè)內(nèi)置函數(shù),用于將一個(gè)字符串解析成浮點(diǎn)數(shù),這個(gè)方法對(duì)于處理用戶輸入、從文本文件讀取數(shù)據(jù)或者在Web API中獲取數(shù)值尤其重要,本文將詳細(xì)介紹parseFloat的工作原理、使用方法以及通過(guò)代碼案例展示其在實(shí)際開(kāi)發(fā)中的應(yīng)用2025-02-02


