国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

javascript - 求解答:實例對象調用constructor,此時constructor內的this的指向?

瀏覽:207日期:2023-04-07 11:13:12

問題描述

這個問題其實來自分析jQuery源碼的時候,看到里面使用了var ret = jQuery.merge(this.constructor(), elems );,里面this.constructor()返回的是init方法創建的空的實例對象。因此對其中this的指向產生疑惑。以下為試驗代碼:

function Person() { this.name = ’ddadaa’; console.log(this);}var p1 = new Person();p1.constructor();// Person {name: 'ddadaa'}var p2 = p1.constructor;p2(); //打印的是window

此處為什么直接調用constructor(),里面的this的指向就發生了改變,并且自動創建了一個新的對象?是不是constructor()方法的內部實現對此有所影響?

問題解答

回答1:

這個和constructor()方法的內部實現沒有什么關系,其實就是函數內this指向的問題。當函數作為對象的屬性調用的時候,this指向這個對象;當函數直接調用的時候,在非嚴格模式下,this指向window;p1.constructor指向的就是Person函數,當調用p1.constructor();時,Person是作為p1的屬性調用的,所以this指向p1;當調用var p2 = p1.constructor;p2();時,其實就相當于直接調用Person();,所以this指向window。

標簽: JavaScript
主站蜘蛛池模板: 中国hd高清╳xxx | 日本精品一在线观看视频 | 依人久久| 99午夜高清在线视频在观看 | 日韩免费高清 | 久久香蕉精品成人 | 国产午夜永久福利视频在线观看 | 美国毛片毛片全部免费 | 欧美日韩一区二区三区高清不卡 | 男人亚洲天堂 | 久久精品2020 | 国产精品9999久久久久 | 精品韩国主播福利视频在线观看一 | 99热久久精品国产 | 欧美叫床戏做爰无遮挡 | 精品在线播放视频 | 日本精品视频一视频高清 | 亚洲视频黄 | 中文字幕亚洲高清综合 | 国内精品a | 国产高清一区二区三区免费视频 | 九九99精品 | 日本理论片免费高清影视在线观看 | 国产免费黄视频 | 精品性久久 | 欧美日韩一级大片 | 欧美日韩一区二区综合 | 日韩一级精品久久久久 | 99av在线播放| 曰韩一级毛片 | 成人午夜大片免费看爽爽爽 | 99国产在线观看 | 久久久久毛片成人精品 | 欧美视频在线一区二区三区 | 亚洲综合首页 | 亚洲综合国产一区二区三区 | 91香蕉国产线观看免 | 亚洲视频免费播放 | 中文字幕精品一区二区精品 | 老司机成人免费精品视频 | 老头老太做爰xxx视频 |