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

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

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

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

問題描述

這個問題其實來自分析jQuery源碼的時候,看到里面使用了var ret = jQuery.merge(this.constructor(), elems );,里面this.constructor()返回的是init方法創(chuàng)建的空的實例對象。因此對其中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的指向就發(fā)生了改變,并且自動創(chuàng)建了一個新的對象?是不是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
主站蜘蛛池模板: 男人天堂视频在线观看 | 99re6在线视频精品免费 | 日韩a在线 | 黄色片亚洲 | 激情影院久久 | 国产精品69毛片高清亚洲 | 逼逼视频 | 国产亚洲一区二区在线观看 | 亚洲一区中文 | 日韩精品视频在线观看一区二区三区 | 99精品欧美一区二区三区综合在线 | 日韩中文欧美 | 国产精品美女久久久 | 国产精品久久久久婷婷二区次 | 日韩久久成人 | 国产精品视频在线观看 | 国产你懂的在线观看 | 久久aⅴ乱码一区二区三区 亚洲欧美综合精品另类天天更新 | 免费在线观看h片 | 亚洲av一级毛片 | 懂色av色香蕉一区二区蜜桃 | 韩日精品一区 | 亚洲一区久久 | 天天色天天射天天干 | 免费一区二区三区 | 欧美成人激情 | 亚洲网在线 | 日韩高清中文字幕 | 欧美一区在线视频 | 中文字幕综合在线 | 国产精品亚洲综合 | 美女福利视频 | 久久久性色精品国产免费观看 | 天天澡天天操 | 99草免费视频| 成人午夜 | 福利网站导航 | 国产精品永久免费 | 国产视频二区 | 一区二区三区四区不卡视频 | 国产一区91精品张津瑜 |