三張圖帶你搞懂JavaScript的原型對(duì)象與原型鏈
對(duì)于新人來(lái)說(shuō),JavaScript的原型是一個(gè)很讓人頭疼的事情,一來(lái)prototype容易與__proto__混淆,二來(lái)它們之間的各種指向?qū)嵲谟行?fù)雜,其實(shí)市面上已經(jīng)有非常多的文章在嘗試說(shuō)清楚,有一張所謂很經(jīng)典的圖,上面畫了各種線條,一會(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)的老鳥都不一定能完全說(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
到此這篇關(guān)于JavaScript原型對(duì)象與原型鏈的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript基礎(chǔ)語(yǔ)法——全面理解變量和標(biāo)識(shí)符
下面小編就為大家?guī)?lái)一篇javascript基礎(chǔ)語(yǔ)法——全面理解變量和標(biāo)識(shí)符。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧2016-06-06ajax上傳時(shí)參數(shù)提交不更新等相關(guān)問(wèn)題
我感覺好像這個(gè)上傳插件只在第一次點(diǎn)擊的時(shí)候?qū)嵗?shù)傳給后臺(tái),所以以后值都是不變的,應(yīng)該怎么解決這個(gè)問(wèn)題呢2012-12-12JavaScript函數(shù)中上下文有哪些規(guī)則
上下文是從英文context翻譯過(guò)來(lái),指的是一種環(huán)境。在軟件工程中,上下文是一種屬性的有序序列,它們?yōu)轳v留在環(huán)境內(nèi)的對(duì)象定義環(huán)境。在對(duì)象的激活過(guò)程中創(chuàng)建上下文,對(duì)象被配置為要求某些自動(dòng)服務(wù)。又比如計(jì)算機(jī)技術(shù)中,相對(duì)于進(jìn)程而言,上下文就是進(jìn)程執(zhí)行時(shí)的環(huán)境2021-10-10將光標(biāo)定位于輸入框最右側(cè)實(shí)現(xiàn)代碼
如何將光標(biāo)定位于輸入框最右側(cè)的實(shí)現(xiàn)方式,這種做法很多人都需要,本文將詳細(xì)介紹,需要的朋友可以參考下2012-12-12JavaScript高級(jí)程序設(shè)計(jì)(第3版)學(xué)習(xí)筆記13 ECMAScript5新特性
通常而言,JavaScript由ECMAScript核心、BOM和DOM三部分構(gòu)成,前面的文章將ECMAScript核心部分粗略的過(guò)了一篇2012-10-10