如何自己實現(xiàn)JavaScript的new操作符
構造函數(shù)
在介紹new之前,必須要知道什么是構造函數(shù)。
構造函數(shù)和普通函數(shù)在寫法上沒有任何區(qū)別,當一個函數(shù)通過new Fun()調(diào)用時,就叫做構造函數(shù),構造函數(shù)首字母通常大寫。
function User(name) {
this.name = name;
}
let u = new User('leo');
這里,User就是構造函數(shù),當然你也可以直接調(diào)用User(),但是這樣就起不到創(chuàng)建實例的作用,在非嚴格模式下,會把name屬性掛在window上。
new 操作符
那么new操作符到底做了什么事情呢,可以創(chuàng)建出一個實例?
new運算符創(chuàng)建一個用戶定義的對象類型的實例或具有構造函數(shù)的內(nèi)置對象的實例。new關鍵字會進行如下的操作:
1.創(chuàng)建一個空的簡單JavaScript對象(即**{}**);
2.鏈接該對象(即設置該對象的構造函數(shù))到另一個對象 ;
3.將步驟1新創(chuàng)建的對象作為**this**的上下文 ;
4.如果該函數(shù)沒有返回對象,則返回**this**。
以上引用自new 操作符 - MDN
可能第 2、4 步大家看的不是很明白,這里我重新總結一下這 4 個步驟:
1.創(chuàng)建一個空對象u = {}
2.綁定原型,u.__proto__ = User.prototype
3.調(diào)用User()函數(shù),并把空對象u當做this傳入,即User.call(u)
4.如果User()函數(shù)執(zhí)行完自己return一個object類型,那么返回此變量,否則返回this,注意:如果構造函數(shù)返回基本類型值,則不影響,還是返回this
自己實現(xiàn)一個 new
知道了new操作符的原理,下面我們自己來實現(xiàn)一個FakeNew函數(shù)。
function FakeNew() {
let obj = {};
// 將類數(shù)組 arguments 轉(zhuǎn)為數(shù)組,同時將第一個參數(shù)也就是構造函數(shù) shift 出來
let constructor = [].shift.apply(arguments);
// 綁定原型
obj.__proto__ = constructor.prototype;
// 調(diào)用構造函數(shù),將 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());
相應關鍵步驟的注釋已經(jīng)附在代碼里面了,這樣我們就實現(xiàn)了一個new操作,相信大家以后再看到new,會有一種通透的感覺了。
以上就是如何自己實現(xiàn)JavaScript的new操作符的詳細內(nèi)容,更多關于JavaScript的new操作符的資料請關注腳本之家其它相關文章!
相關文章
解析javascript瀑布流原理實現(xiàn)圖片滾動加載
這篇文章主要幫助大家解析javascript瀑布流原理,實現(xiàn)js圖片滾動加載2016-03-03
淺談javascript 函數(shù)表達式和函數(shù)聲明的區(qū)別
javascript中聲明函數(shù)的方法有兩種:函數(shù)聲明式和函數(shù)表達式.究竟他們用起來有什么區(qū)別呢,今天就本著打破砂鍋問到底的精神,好好來說說這個讓人神魂顛倒的--函數(shù)聲明。2016-01-01
基于mouseout和mouseover等類似事件的冒泡問題解決方法
這篇文章主要介紹了關于mouseout和mouseover等類似事件的冒泡問題解決方法。需要的朋友可以過來參考下,希望對大家有所幫助2013-11-11
解決微信授權成功后點擊按返回鍵出現(xiàn)空白頁和報錯的問題
這篇文章主要介紹了解決微信授權成功后點擊按返回鍵出現(xiàn)空白頁和報錯的問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-06-06

