欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

如何進(jìn)行new操作符的原理解析

本篇文章給大家分享的是有關(guān)如何進(jìn)行new操作符的原理解析,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

創(chuàng)新互聯(lián)建站專注于企業(yè)營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、連城網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、成都h5網(wǎng)站建設(shè)電子商務(wù)商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為連城等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

前端面試—new操作符的原理解析

new實(shí)例

JavaScript中new操作符用于創(chuàng)建一個(gè)給定構(gòu)造函數(shù)的對(duì)象實(shí)例

function Person(name, age){
	this.name = name;
	this.age = age;
}
const res = new Person('Tom', 20)
console.log(res)  // Person {name: "Tom", age: 20}
原型,構(gòu)造函數(shù),實(shí)例的關(guān)系
  • 原型(prototype):一個(gè)簡(jiǎn)單的對(duì)象,用于實(shí)現(xiàn)對(duì)象的屬性繼承。可以簡(jiǎn)單理解成對(duì)象的父親。在火狐和谷歌中,每個(gè)js對(duì)象中都包含一個(gè)**proto**(非標(biāo)準(zhǔn))的屬性指向它爹(該對(duì)象原型),可obj.__proto__進(jìn)行訪問。

  • 構(gòu)造函數(shù):可以 通過new來新建一個(gè)對(duì)象的函數(shù)。

  • 實(shí)例:通過 構(gòu)造函數(shù)new創(chuàng)建出來的 對(duì)象,就是實(shí)例。實(shí)例通過**proto指向原型,通過constructor**指向構(gòu)造函數(shù)。

因此看得出三者的關(guān)系
實(shí)例.__proto__===原型
原型.constructor === 構(gòu)造函數(shù)
構(gòu)造函數(shù).prototype === 原型
實(shí)例.constructor === 構(gòu)造函數(shù)
new操作符實(shí)現(xiàn)原理
  • 新生成一個(gè)對(duì)象

  • 鏈接到原型

  • 綁定this

  • 返回新對(duì)象(如果構(gòu)造函數(shù)有自己 retrun 時(shí),則返回該值)

function myNew(constrc, ...args) {
	const obj = {}; // 1. 創(chuàng)建一個(gè)空對(duì)象
	obj.__proto__ = constrc.prototype; // 2. 將obj的[[prototype]]屬性指向構(gòu)造函數(shù)的原型對(duì)象
	const result = constrc.apply(obj, args); // 3.將constrc執(zhí)行的上下文this綁定到obj上,并執(zhí)行
	return result instanceof Object ? result : obj;  //4. 如果構(gòu)造函數(shù)返回的是對(duì)象,則使用構(gòu)造函數(shù)執(zhí)行的結(jié)果。否則,返回新創(chuàng)建的對(duì)象
}

// 使用的例子:
function Person(name, age){
	this.name = name;
	this.age = age;
}
const res = myNew(Person, 'Tom', 20)
console.log(res)  // Person {name: "Tom", age: 20}

以上就是如何進(jìn)行new操作符的原理解析,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

分享標(biāo)題:如何進(jìn)行new操作符的原理解析
網(wǎng)站網(wǎng)址:http://chinadenli.net/article4/jgjgie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營(yíng)銷推廣網(wǎng)站營(yíng)銷網(wǎng)站設(shè)計(jì)網(wǎng)站制作虛擬主機(jī)網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)