成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

詳解JavaScript原型與原型鏈

瀏覽:93日期:2023-10-08 13:11:46

正如一些面向對象語言中所實現的那樣,在JavaScript中我們有時也需要創建一個擁有公共函數與屬性的類作為父類來減少代碼重復、實現類型檢查與實現更加清晰地代碼結構。在JavaScript中,繼承是通過原型鏈實現的。了解JavaScript的繼承與原型鏈之前首先需要了解JavaScript中對象創建的方式。

在JavaScript中創建對象

JavaScript中對象創建的方式有兩種:工廠方法(Factory Functions)、構造器方法(Constructor Functions) 。

工廠方法

工廠方法在編程領域是一個非類或構造器的返回對象的方法。在JavaScript中,任何返回不使用new關鍵詞創建對象的方法都是工廠方法。

function person(firstName, lastName, age) { const person = {}; person.firstName = firstName; person.lastName = lastName; person.age = age; return person;}

構造器方法

構造器方法和工廠方法的區別僅在用例和命名規范上。命名規范上一個構造器方法的名字開頭字母需要大寫,我們需要通過new關鍵詞來調用構造器方法生成實例。這個實例之后便可以通過instanceof關鍵詞來檢查。

function Person(firstName, lastName, age) { this.firstName = firstName; this.lastName = lastName; this.age = age;}

new的行為

當同時在工廠方法和構造器方法上使用new關鍵詞創建時,工廠方法創建出的對象的__proto__屬性指向Object.prototype,構造器方法創建出的對象的__proto__屬性指向本身的Xxx.prototype。

const mike = new person(’mike’, ’grand’, 23);mike.__proto__// Object.prototype

const jack = new Person(’jack’, ’grand’, 23);jack.__proto__// Person.protytype這里的prototype指向Person的Prototype Objectjack.__proto__.__proto__// Object.prototype

new關鍵詞在后臺為構造器方法執行了以下幾步

在構造器方法內創建一個新對象并將其賦值到this上 設置對象的[[Prototype]]和__proto__為原型的構造函數,這一步也讓新對象的構造函數在構造新對象時被添加到原型鏈上 如果這個方法內沒有返回object、function或array類型的結果,就返回this 如果這個方法內沒有返回任何值則返回this

下面是一個展示new關鍵詞在JavaScript引擎當中執行效果的偽代碼,注釋當中的是用來示范new關鍵詞添加語句的偽代碼

function Person(firstName, lastName, age) { // this = {}; // this.__proto__ = Person.prototype; this.firstName = firstName; this.lastName = lastName; this.age = age; // return this;}

在構造器方法上沒有返回值所以后臺創建的this將被返回,而工廠方法內由于返回了對象所以后臺不再添加return this自然返回的內容將不一致。

如果沒有在構造器方法前使用new關鍵詞,而將構造器方法直接調用執行,其僅作為一個方法來被執行而非構造器。

const bob = Person(’bob’, ’grand’, 23);bob// undefined. 因為這里Person當作方法直接調用了且沒有返回值window.firstName// bob. 函數內的this將指向全局作用域,導致意外操作

繼承與原型鏈

原型

原型(Prototype)可以認為是一個JavaScript方法的屬性,每次在JavaScript代碼中創建方法時,JavaScript引擎會將一個名為prototype的屬性添加上去,這個prototype屬性是一個對象(原型對象),這個對象默認有一個constructor屬性指向原方法對象。任何添加到prototype的屬性和方法都在這個對象里面,所有該類實例共享這個原型對象,實例對象的__proto__屬性指向這個對象,方法的prototype屬性指向這個對象。

在ECMAScript的標準里object.[[Prototype]]是訪問原型的方法,但在ECMAScript 2015中用Object.getPrototypeOf()和Object.setPrototypeOf()來替代。等價的__proto__是多數瀏覽器使用的事實上的但是非標準的實現。

function Person(firstName, lastName, age) { this.firstName = firstName; this.lastName = lastName; this.age = age;}Person.prototype === Person.prototype.constructor.prototype// 指向Person的原型對象Person.prototype.constructor === Person// 指向Person方法對象let bob = new Person('Bob', 'Ross', 21);Person.prototype === bob.__proto__;// truelet alex = new Person('Alex', 'Wang', 21);Person.prototype === alex.__proto__;// truealex.__proto__ === bob.__proto__;// true

原型鏈

首先我們需要了解對象查找機制。當我們使用一個對象的屬性時,JavaScript引擎會首先查找本對象里是否有對應屬性,如果沒有則去對象的原型里查找屬性,如果沒有則去對象的原型對象的原型對象里查找屬性,直至查詢到對象的__proto__為null的時候停止。

詳解JavaScript原型與原型鏈

const obj = {};console.log(obj);// [object Object]obj的toString()方法從Object的原型中查找到并使用function Person(firstName, lastName, age) { this.firstName = firstName; this.lastName = lastName; this.age = age; // 在Person.prototype上定義了toString覆寫了Object.prototype上的toString Person.prototype.toString = function() { return `${this.firstName} It Is`; }}let bob = new Person('Bob', 'Ross', 21);let alex = new Person('Alex', 'Wang', 21);console.log(bob);// Bob It Isconsole.log(alex);// Alex It Is

以上就是詳解JavaScript原型與原型鏈的詳細內容,更多關于JavaScript原型與原型鏈的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
欧美精品一线| 成人av高清在线| 国产激情91久久精品导航| 亚洲麻豆视频| 中文字幕一区三区| 欧美日韩日本网| 久久久不卡影院| 99久久综合国产精品| 日韩欧美一级片| 国产69精品久久久久毛片| 欧美二区三区91| 狠狠色丁香久久婷婷综| 色域天天综合网| 午夜亚洲国产au精品一区二区| 一本色道婷婷久久欧美| 一区二区三区四区av| 一道本一区二区| 亚洲欧洲综合另类在线| 亚洲成人中文| 亚洲欧美国产三级| 日韩午夜高潮| 亚洲国产日韩一区二区| 六月婷婷一区| 美女一区二区三区在线观看| 欧美日韩在线播放三区四区| 精品夜夜嗨av一区二区三区| 欧美日韩mp4| 国内精品久久久久影院色| 欧美日韩久久久| 国产精品综合在线视频| 日韩欧美色综合网站| 国产不卡视频一区| 精品女同一区二区| 99久久久久久99| 国产人伦精品一区二区| 国语自产精品视频在线看8查询8| 亚洲视频免费在线观看| 一区二区三区导航| 亚洲成a人v欧美综合天堂下载 | 99re亚洲国产精品| 国产欧美一区二区精品性| 影音先锋中文字幕一区二区| 亚洲欧美偷拍三级| 国产农村妇女精品一区二区| 天堂精品中文字幕在线| 欧美丝袜丝交足nylons| 国产精品性做久久久久久| 精品精品国产高清a毛片牛牛| 欧美xx69| 依依成人精品视频| 日本福利一区二区| 国产成人午夜电影网| 日韩欧美国产1| 欧美精品亚洲| 亚洲综合一区二区三区| 欧美综合一区二区| 成人ar影院免费观看视频| 国产精品福利影院| 亚欧美中日韩视频| 狠狠狠色丁香婷婷综合久久五月| 日韩欧美二区三区| 很黄很黄激情成人| 日韩中文字幕一区二区三区| 欧美一区二区三区四区视频 | 亚洲午夜视频| 首页亚洲欧美制服丝腿| 欧美精品久久天天躁| 欧美一区1区三区3区公司| 一区二区三区精品在线| 欧美吞精做爰啪啪高潮| 91丝袜美女网| 亚洲一区二区三区爽爽爽爽爽| 日本韩国欧美国产| jlzzjlzz亚洲女人18| 亚洲男人的天堂av| 欧美三级日韩三级国产三级| 91免费看`日韩一区二区| 亚洲品质自拍视频网站| 欧美日韩一区二区不卡| 欧美成人一品| 日韩精品国产精品| 宅男在线国产精品| 韩日视频一区| 狂野欧美性猛交blacked| 国产欧美一区二区三区沐欲| 色8久久人人97超碰香蕉987| 99久久婷婷国产综合精品电影 | 亚洲欧洲精品一区二区| 蜜桃久久久久久| 欧美精品一区二区三区四区 | 国产日韩精品一区观看| 国模冰冰炮一区二区| 国产精品久久久久永久免费观看| 久久精品五月| 99精品视频一区| 婷婷久久综合九色综合绿巨人| 久久婷婷成人综合色| 久久久久久久欧美精品| www.欧美.com| 婷婷国产v国产偷v亚洲高清| 久久午夜老司机| 一本到三区不卡视频| 91在线观看成人| 亚洲二区视频在线| 精品国产乱码91久久久久久网站| 国产精品日韩欧美一区二区三区| 国产一区二区调教| 亚洲欧美日韩精品久久久久| 欧美一级在线视频| 国产日韩欧美一区二区三区在线观看| 国产成人在线色| 亚洲国产精品久久艾草纯爱| 欧美mv和日韩mv国产网站| 免费看黄裸体一级大秀欧美| 91亚洲永久精品| 蜜桃精品在线观看| 中国av一区二区三区| 91精品国产免费久久综合| 999亚洲国产精| 不卡一区二区三区四区| 日韩av一二三| 亚洲欧洲中文日韩久久av乱码| 日韩精品在线一区| 91搞黄在线观看| 亚洲伦伦在线| 午夜天堂精品久久久久| 国产福利电影一区二区三区| 日韩精品午夜视频| 自拍偷在线精品自拍偷无码专区| 91精品午夜视频| 日本韩国欧美一区| 一区二区三区四区五区精品| 欧美1区2区| 久草中文综合在线| 亚洲国产精品一区二区www在线| 国产精品丝袜久久久久久app| 日韩一二三四区| 欧美亚洲综合久久| 国产精品日韩欧美一区| 一区在线视频观看| 91亚洲男人天堂| 国产永久精品大片wwwapp| 丝袜诱惑制服诱惑色一区在线观看| 国产精品污www在线观看| 日韩免费看的电影| 欧美巨大另类极品videosbest| 久久国产免费| 亚洲激情视频| 欧美一区免费| www.亚洲人| 国产高清精品网站| 精品一区二区三区在线视频| 日韩不卡一区二区| 午夜日韩在线观看| 亚洲综合久久av| 亚洲狠狠丁香婷婷综合久久久| 国产精品免费看片| 国产欧美一区二区精品秋霞影院| 日韩免费高清av| 欧美一区二区三区在线视频| 欧美系列一区二区| 色婷婷久久综合| 久久一日本道色综合久久| 国产精品久久久久久久久久妞妞| 亚洲高清在线| 激情欧美一区| 国内久久精品| 欧美日韩一区在线播放| 欧美精品亚洲精品| 午夜国产精品视频| 色综合久久综合网欧美综合网| 99久久99久久精品国产片果冻| 波多野结衣中文字幕一区| 国产成人精品网址| 国产成人精品一区二| 成人性生交大片免费看视频在线| 国产不卡在线播放| 成人av午夜电影| 国产v日产∨综合v精品视频| 国产精品99精品久久免费| 国产成人av一区二区三区在线| 国产伦理精品不卡| 丁香五精品蜜臀久久久久99网站 | bt欧美亚洲午夜电影天堂| 99在线热播精品免费| 99re热这里只有精品视频| 99久久伊人久久99| 欧美区国产区| 在线看片日韩| 国产精品日本| 日本电影亚洲天堂一区| 老牛影视一区二区三区| 在线看一区二区| 欧美精品一二三四| 精品入口麻豆88视频| 国产日韩欧美不卡在线| 中文字幕日本不卡| 亚洲一区二区三区四区的| 男女男精品视频网| 久久成人久久爱|