av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

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

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

瀏覽:173日期: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
主站蜘蛛池模板: 国产精品久久久久不卡 | 国产盗摄视频 | 操操日 | 亚洲视频在线一区 | 欧美狠狠操| 欧美日韩中文字幕在线 | h片免费在线观看 | 国产精品久久久久久一区二区三区 | 久久人体视频 | 99视频入口 | 综合九九 | av一区二区在线观看 | 亚州精品天堂中文字幕 | 日韩精品一区二区三区中文在线 | 99精彩视频| 久久99精品久久久久久 | 久久精品视频网站 | 一区二区三区视频播放 | 日韩在线免费 | 日本精品视频 | 欧美一区二区大片 | 久久亚洲一区 | 日本不卡一区二区三区 | 精久久久久 | 成人在线不卡 | 久久欧美精品 | 一区二区三区在线免费观看 | 久久一区二区视频 | 99精品久久99久久久久 | 国产一区二区日韩 | 成年人网站免费视频 | 成人国内精品久久久久一区 | 精品日韩在线观看 | 国产精品久久久久久亚洲调教 | 91久久国产综合久久 | 国产精品国产三级国产aⅴ原创 | 在线亚洲电影 | 麻豆一区 | 亚洲欧洲成人av每日更新 | 亚洲欧美国产视频 | 欧美日韩精品综合 |