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è)引用類(lèi)型值,則 new 操作最終返回這個(gè)引用類(lèi)型值;否則返回剛創(chuàng)建的新對(duì)象。 引用類(lèi)型值:除基本類(lèi)型值(數(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í)例,即是否為引用類(lèi)型值;這是因?yàn)樗幸妙?lèi)型值都是 Object 的實(shí)例,Object 是所有引用類(lèi)型值的基類(lèi)型。
好了,到此這篇關(guān)于JavaScript中new操作符原理的文章就介紹到這了,更多相關(guān)JS new操作符原理內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. nodejs報(bào)digital envelope routines::unsupported錯(cuò)誤的最新解決方法2. 匹配模式 - XSL教程 - 43. javascript xml xsl取值及數(shù)據(jù)修改第1/2頁(yè)4. 詳解JS前端使用迭代器和生成器原理及示例5. WML語(yǔ)法大全與相關(guān)介紹第1/3頁(yè)6. 詳解CSS偽元素的妙用單標(biāo)簽之美7. 使用css實(shí)現(xiàn)全兼容tooltip提示框8. asp中response.write("中文")或者js中文亂碼問(wèn)題9. ASP刪除img標(biāo)簽的style屬性只保留src的正則函數(shù)10. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向
