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

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

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

瀏覽:215日期: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
主站蜘蛛池模板: 午夜国产| 中文字幕视频在线 | 欧美大片18| 99精品99 | 国产成人精品一区二区三区视频 | 久久在线 | 日本特黄特色aaa大片免费 | 三级视频网 | 欧美日韩性 | 成年免费视频黄网站在线观看 | 欧美在线激情 | 国产精品av在线 | 亚洲综合视频在线观看 | 午夜视频在线免费观看 | www色| 日本乱轮视频 | 日韩欧美影院 | 亚洲精品久久久久avwww潮水 | 91成人国产 | 日产毛片 | 国产中文字幕在线播放 | 成人激情在线 | 欧美成人三级 | 日韩一区二区三区在线 | 国产无遮挡又黄又爽免费网站 | 亚洲天堂网站 | 日韩欧美一区在线 | 国产综合一区二区 | 青青草av| 日韩黄色影院 | 毛片免费观看视频 | 国产精品午夜视频 | 日韩成人三级 | 精品一区二区免费视频 | 日韩黄网| 日韩高清在线 | 天天天天天操 | 国产区一区二区 | 成人黄色在线 | 国产精品伦理一区 | 亚洲 欧美 日韩 在线 |