JavaScript中new操作符的原理示例詳解
new的作用是通過(guò)構(gòu)造函數(shù)來(lái)創(chuàng)建一個(gè)實(shí)例對(duì)象,該實(shí)例與原型和構(gòu)造函數(shù)之間的關(guān)系如下圖所示:
執(zhí)行 new 操作時(shí)會(huì)依次經(jīng)過(guò)以下步驟:
1、創(chuàng)建一個(gè)空對(duì)象
空對(duì)象是 Object 的實(shí)例,即 {} 。let obj = {}
2、空對(duì)象的內(nèi)部屬性 __proto__ 賦值為構(gòu)造函數(shù)的 prototype 屬性
該操作是為了將空對(duì)象鏈接到正確的原型上去function Foo(num) { this.number = num}obj.__proto__ = Foo.prototype
3、將構(gòu)造函數(shù)的 this 指向空對(duì)象
即構(gòu)造函數(shù)內(nèi)部的 this 被賦值為空對(duì)象,以便后面正確執(zhí)行構(gòu)造函數(shù)。Foo.call(obj, 1)
4、執(zhí)行構(gòu)造函數(shù)內(nèi)部代碼
即給空對(duì)象添加屬性、方法。5、返回該新對(duì)象
如果構(gòu)造函數(shù)內(nèi)部通過(guò) return 語(yǔ)句返回了一個(gè)引用類型值,則 new 操作最終返回這個(gè)引用類型值;否則返回剛創(chuàng)建的新對(duì)象。 引用類型值:除基本類型值(數(shù)值、字符串、布爾值、null、undefined、Symbol 值)以外的所有值。模擬 new 操作符下面的 myNew 函數(shù)模擬了 new 操作符的行為
function myNew(func, ...args) { let obj = {} obj.__proto__ = func.prototype let res = func.apply(obj, args) return res instanceof Object ? res : obj}function Foo(num) { this.number = num}let foo1 = myNew(Foo, 1)console.log(foo1 instanceof Foo) // trueconsole.log(foo1.number) // 1let foo2 = new Foo(2)console.log(foo2 instanceof Foo) // trueconsole.log(foo2.number) // 2
上面通過(guò) instanceof 操作符來(lái)判斷構(gòu)造函數(shù)的返回值是否為 Object 的實(shí)例,即是否為引用類型值;這是因?yàn)樗幸妙愋椭刀际?Object 的實(shí)例,Object 是所有引用類型值的基類型。
好了,到此這篇關(guān)于JavaScript中new操作符原理的文章就介紹到這了,更多相關(guān)JS new操作符原理內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 如何利用python操作注冊(cè)表2. Xml簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理3. jsp文件下載功能實(shí)現(xiàn)代碼4. 詳解瀏覽器的緩存機(jī)制5. ASP動(dòng)態(tài)網(wǎng)頁(yè)制作技術(shù)經(jīng)驗(yàn)分享6. jsp實(shí)現(xiàn)登錄驗(yàn)證的過(guò)濾器7. phpstudy apache開(kāi)啟ssi使用詳解8. vue3+ts+elementPLus實(shí)現(xiàn)v-preview指令9. 如何在jsp界面中插入圖片10. JSP之表單提交get和post的區(qū)別詳解及實(shí)例
