亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

如何自己實現JavaScript的new操作符

瀏覽:40日期:2023-09-30 13:54:26
構造函數

在介紹new之前,必須要知道什么是構造函數。

構造函數和普通函數在寫法上沒有任何區別,當一個函數通過new Fun()調用時,就叫做構造函數,構造函數首字母通常大寫。

function User(name) { this.name = name;}let u = new User(’leo’);

這里,User就是構造函數,當然你也可以直接調用User(),但是這樣就起不到創建實例的作用,在非嚴格模式下,會把name屬性掛在window上。

new 操作符

那么new操作符到底做了什么事情呢,可以創建出一個實例?

new運算符創建一個用戶定義的對象類型的實例或具有構造函數的內置對象的實例。new關鍵字會進行如下的操作:

1.創建一個空的簡單JavaScript對象(即**{}**);

2.鏈接該對象(即設置該對象的構造函數)到另一個對象 ;

3.將步驟1新創建的對象作為**this**的上下文 ;

4.如果該函數沒有返回對象,則返回**this**。

以上引用自new 操作符 - MDN

可能第 2、4 步大家看的不是很明白,這里我重新總結一下這 4 個步驟:

1.創建一個空對象u = {}

2.綁定原型,u.__proto__ = User.prototype

3.調用User()函數,并把空對象u當做this傳入,即User.call(u)

4.如果User()函數執行完自己return一個object類型,那么返回此變量,否則返回this,注意:如果構造函數返回基本類型值,則不影響,還是返回this

自己實現一個 new

知道了new操作符的原理,下面我們自己來實現一個FakeNew函數。

function FakeNew() { let obj = {}; // 將類數組 arguments 轉為數組,同時將第一個參數也就是構造函數 shift 出來 let constructor = [].shift.apply(arguments); // 綁定原型 obj.__proto__ = constructor.prototype; // 調用構造函數,將 obj 當做 this 傳入 let res = Constructor.apply(obj, arguments);// 返回 return typeof res === ’object’ ? res : obj; }function User(name) { this.name = name;}User.prototype.getName = function() { return this.name;}let u = FakeNew(User, ’leo’);console.log(u);console.log(u.getName());

相應關鍵步驟的注釋已經附在代碼里面了,這樣我們就實現了一個new操作,相信大家以后再看到new,會有一種通透的感覺了。

以上就是如何自己實現JavaScript的new操作符的詳細內容,更多關于JavaScript的new操作符的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 欧美精品做人一级爱免费 | 久久久久亚洲精品中文字幕 | 精品中文字幕不卡在线视频 | 在线欧洲成人免费视频 | 亚洲国产七七久久桃花 | 国产tv在线| 狠狠色成人综合网图片区 | 欧美大片在线观看 | 亚洲国产一区二区三区四区五区 | 亚洲国产成人久久笫一页 | 91精品国产色综合久久不卡蜜 | 国产精品久久久久这里只有精品 | 日韩 国产 欧美 精品 在线 | 婷婷亚洲天堂 | 国产在线观看网址在线视频 | 欧美高清a| 国产精品亚洲精品 | 国产成人精品微拍视频 | 国产精品视频分类一区 | 忘忧草综合久久综合88亚洲 | 精品视频第一页 | 在线观看激情偷拍视频 | 国产不卡视频 | 草草影院ccyy国产日本欧美 | www.麻豆.com| 91精品啪在线观看国产日本 | 久久精品亚洲一区二区三区浴池 | 亚洲狠狠狠一区二区三区 | 国产成人禁片免费观看视频 | 午夜在线成人 | 欧美人成在线观看网站高清 | 亚洲国产精品一区二区第四页 | 国产高清一级毛片 | 国产人成亚洲第一网站在线播放 | 久久免费精品 | 欧美真人视频一级毛片 | 美国一级毛片片免费 | 日本一区二区三区精品视频 | 欧美综合在线播放 | 久久婷婷丁香 | 求免费黄色网址 |