日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

一张图理解JS的原型(prototype、_proto_、constructor的三角关系)

發布時間:2025/3/8 javascript 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 一张图理解JS的原型(prototype、_proto_、constructor的三角关系) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

注意:前方高能預警,請認真仔細看完,閱讀完后自己再次畫下原型圖,相信你一定會有更深刻的認識。(推薦炒雞好用的畫流程圖的軟件ProcessOn)

構造函數:function Foo ( ) { };

實例對象:let f1=new Foo;

let o1=new Foo;

每個函數都有 prototype 屬性,除了 Function.prototype.bind(),該屬性指向原型。

每個對象都有 __proto__ 屬性,指向了創建該對象的構造函數的原型。其實這個屬性指向了 [[prototype]],但是 [[prototype]] 是內部屬性,我們并不能訪問到,所以使用 _proto_ 來訪問。

對象可以通過 __proto__ 來尋找不屬于該對象的屬性,__proto__ 將對象連接起來組成了原型鏈。

?

下面我們來解釋上圖的原型圖的含義:

概念:

1、構造函數:用來初始化新創建的對象的函數是構造函數。在例子中,Foo()函數是構造函數。

2、實例對象:通過構造函數的new操作創建的對象是實例對象。可以用一個構造函數,構造多個實例對象。

function Foo(){}; var f1 = new Foo; var f2 = new Foo; console.log(f1 === f2);//false復制代碼

3、原型對象及prototype:構造函數有一個prototype屬性,指向實例對象的原型對象。通過同一個構造函數實例化的多個對象具有相同的原型對象。經常使用原型對象來實現繼承。

function Foo(){}; Foo.prototype.a = 1; var f1 = new Foo; var f2 = new Foo;console.log(Foo.prototype.a);//1 console.log(f1.a);//1 console.log(f2.a);//1復制代碼

4、constructor:原型對象有一個constructor屬性,指向該原型對象對應的構造函數。由于實例對象可以繼承原型對象的屬性,所以實例對象也擁有constructor屬性,同樣指向原型對象對應的構造函數。

console.log(Foo.prototype.constructor === Foo);//true console.log(f1.constructor === Foo);//true復制代碼

5、_proto_:實例對象有一個proto屬性,指向該實例對象對應的原型對象。

console.log(f1.__proto__ === Foo.prototype);//true復制代碼

概念介紹完了,現在對圖示的關系進行詳細說明

【第一部分: Foo】

?

1、實例對象f1是通過構造函數Foo()的new操作創建的。構造函數Foo()的原型對象是Foo.prototype;實例對象f1通過__proto__屬性也指向原型對象Foo.prototype。

console.log(f1.__proto === Foo.prototype);//true 復制代碼

2、實例對象f1本身并沒有constructor屬性,但它可以繼承原型對象Foo.prototype的constructor屬性

console.log(Foo.prototype.constructor === Foo);//true console.log(f1.constructor === Foo);//true console.log(f1.hasOwnProperty('constructor'));//false復制代碼

  下圖是實例對象f1的控制臺效果

?

【第二部分: Object】

?

1、Foo.prototype是f1的原型對象,同時它也是實例對象。實際上,任何對象都可以看做是通過Object()構造函數的new操作實例化的對象 所以,Foo.prototype作為實例對象,它的構造函數是Object(),原型對象是Object.prototype。相應地,構造函數Object()的prototype屬 性指向原型對象Object.prototype;實例對象Foo.prototype的proto屬性同樣指向原型對象Object.prototype。

console.log(Foo.prototype.__proto__ === Object.prototype);//true 復制代碼

2、實例對象Foo.prototype本身具有constructor屬性,所以它會覆蓋繼承自原型對象Object.prototype的constructor屬性。

console.log(Foo.prototype.constructor === Foo);//true console.log(Object.prototype.constructor === Object);//true console.log(Foo.prototype.hasOwnProperty('constructor'));//true復制代碼

  下圖是實例對象Foo.prototype的控制臺效果

?

3、如果Object.prototype作為實例對象的話,其原型對象是什么,結果是null。我以為,這可能也是typeof null的結果是'object'的原因之一吧。

console.log(Object.prototype.__proto__ === null);//true 復制代碼

【第三部分: Function】

?

1、前面已經介紹過,函數也是對象,只不過是具有特殊功能的對象而已。任何函數都可以看做是通過Function()構造函數的new操作實例化的結果。如果把函數Foo當成實例對象的話,其構造函數是Function(),其原型對象是Function.prototype;類似地,函數Object的構造函數也是Function(),其原型對象是Function.prototype。

console.log(Foo.__proto__ === Function.prototype);//true console.log(Object.__proto__ === Function.prototype);//true復制代碼

2、原型對象Function.prototype的constructor屬性指向構造函數Function();實例對象Object和Foo本身沒有constructor屬性,需要繼承原型對象Function.prototype的constructor屬性。

console.log(Function.prototype.constructor === Function);//true console.log(Foo.constructor === Function);//true console.log(Foo.hasOwnProperty('constructor'));//false console.log(Object.constructor === Function);//true console.log(Object.hasOwnProperty('constructor'));//false 復制代碼

3、所有的函數都可以看成是構造函數Function()的new操作的實例化對象。那么,Function可以看成是調用其自身的new操作的實例化的結果。所以,如果Function作為實例對象,其構造函數是Function,其原型對象是Function.prototype。

console.log(Function.__proto__ === Function.prototype);//true console.log(Function.prototype.constructor === Function);//true console.log(Function.prototype === Function.prototype);//true復制代碼

4、如果Function.prototype作為實例對象的話,其原型對象是什么呢?和前面一樣,所有的對象都可以看成是Object()構造函數的new操作的實例化結果。所以,Function.prototype的原型對象是Object.prototype,其原型函數是Object()。

console.log(Function.prototype.__proto__ === Object.prototype);//true 復制代碼

總結:

【1】函數(Function也是函數)是new Function的結果,所以函數可以作為實例對象,其構造函數是Function(),原型對象是Function.prototype。

【2】對象(函數也是對象)是new Object的結果,所以對象可以作為實例對象,其構造函數是Object(),原型對象是Object.prototype

【3】Object.prototype的原型對象是null。



總結

以上是生活随笔為你收集整理的一张图理解JS的原型(prototype、_proto_、constructor的三角关系)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 色伊人av | av优选在线观看 | gogo亚洲国模私拍人体 | 狠狠干天天 | 国语对白做受xxxxx在线中国 | 中文字幕第10页 | 91免费.| 黄色片网站在线播放 | 日本国产精品 | 日韩欧美中文字幕一区二区 | 成人免费一区二区三区在线观看 | 日韩av在线播放网址 | 国产亚洲精久久久久久无码苍井空 | 国产情侣在线视频 | 久久精品国产熟女亚洲AV麻豆 | 国产一区二区不卡在线 | 在线观看免费视频 | 黄a毛片 | 久久久久亚洲精品 | 日韩a∨| 久操网站 | 狠狠操夜夜爽 | 欧美成人午夜视频 | 国产麻豆精品久久一二三 | 亚洲欧洲综合 | 在线不卡日本 | 国产精品一区在线播放 | 亚洲熟妇无码乱子av电影 | 色偷偷久久 | 国产激情对白 | av观看在线免费 | 亚洲欧美高清 | 亚洲综合社区 | 在线高清观看免费 | 日韩城人视频 | 日本精品在线观看视频 | 午夜极品视频 | 性xxx法国hd极品 | 国产免费黄色网址 | 射进来av影视| 久久久久国产精品夜夜夜夜夜 | 性生活免费网站 | 亚洲成人av网址 | 精品一区二区欧美 | 国产第一色 | 亚洲夜夜夜 | 姝姝窝人体www聚色窝 | a黄视频| 免费黄色小视频在线观看 | 成人乱人乱一区二区三区一级视频 | 一区=区三区乱码 | 欧美国产一区二区在线观看 | 亚洲精品乱码久久久久 | 亚洲福利视频一区二区三区 | 日本xxxx在线观看 | 成人福利小视频 | 打开免费观看视频在线 | 国产日韩欧美一二三区 | 欧美猛操 | 欧美一区永久视频免费观看 | 精人妻一区二区三区 | 在线综合视频 | 日本成人片在线 | 日本中文字幕久久 | 蜜芽久久 | 国产a级大片 | 国产精品久久久久久久久久久久久久久久久久 | 国产精品永久免费观看 | 91亚洲国产成人精品一区 | 亚洲乱色熟女一区二区三区 | 欧美freesex黑人又粗又大 | 动漫同人高h啪啪爽文 | 免费网站看av | 偷拍欧美亚洲 | 人成在线视频 | 99艹| 制服丝袜成人动漫 | 海量av资源 | 日本偷拍一区 | 高h视频在线观看 | 久久精品亚洲精品国产欧美 | 久久高清 | 一本大道久久a久久精二百 琪琪色在线视频 | 国产99在线播放 | 久久成人午夜 | 亚洲爱爱av | 亚洲欧美日韩久久 | 色女孩综合网 | 伊人久久大香 | 午夜在线精品 | 91麻豆视频网站 | 麻豆一区二区三区四区 | 97伊人 | 日韩一级免费视频 | 日韩欧美中文字幕一区二区三区 | av老司机在线 | 亚洲午夜精品在线观看 | 性欧美18一19性猛交 | 色吧久久 |