JavaScript中new操作符的原理示例詳解
new的作用是通過構(gòu)造函數(shù)來創(chuàng)建一個(gè)實(shí)例對(duì)象,該實(shí)例與原型和構(gòu)造函數(shù)之間的關(guān)系如下圖所示:
執(zhí)行 new 操作時(shí)會(huì)依次經(jīng)過以下步驟:
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)部通過 return 語句返回了一個(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
上面通過 instanceof 操作符來判斷構(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. vue跳轉(zhuǎn)頁面常用的幾種方法匯總2. XML 非法字符(轉(zhuǎn)義字符)3. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)4. XML入門的常見問題(三)5. 不要在HTML中濫用div6. ASP動(dòng)態(tài)include文件7. 父div高度不能自適應(yīng)子div高度的解決方案8. asp createTextFile生成文本文件支持utf89. Jquery使用原生AJAX方法請(qǐng)求數(shù)據(jù)10. el-input無法輸入的問題和表單驗(yàn)證失敗問題解決
