js的this是比較復雜的一個概念,復雜在于他究竟指代哪個對象,今天就為大家解釋一下。首先,this的指向在函數定義的時候是確定不了的,只有函數執行的時候才能確定this到底指向誰,實際上this的最終指向的是那個調用它的對象。那也就是說,this并不是由函數決定的,而是由最終調用它的對象決定的。
創新互聯2013年至今,是專業互聯網技術服務公司,擁有項目網站建設、成都做網站網站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元邵東做網站,已為上家服務,為邵東各地企業和個人服務,聯系電話:13518219792
例1:
function a(){
var user = "追夢子";
console.log(this.user); //undefinedconsole.log(this); //Window
}
a();
這里調用this的對象是window,a()其實等價于window.a()。
例2:
o.fn();
這里最終調用this的是o這個對象,如果按照這個邏輯,最開始對this的解釋就是成立的;然而要看下面的例子,估計又要一頭霧水了。
例3:
var o = { console.log(this.a); //12
}
}o.b.fn();
如果按照最后誰調取函數的原則,那么這里打印出來的是10,而不應該是12。我的理解是這個this指向調用這個函數的離他最近的對象。這里離函數最近的對象是b,那么this就指代b。
分享文章:js中的this究竟怎么用
網站路徑:http://newbst.com/article46/ijhoeg.html
成都網站建設公司_創新互聯,為您提供網頁設計公司、App開發、ChatGPT、動態網站、網站制作、品牌網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯