js中的this究竟怎么用

js的this是比較復(fù)雜的一個概念,復(fù)雜在于他究竟指代哪個對象,今天就為大家解釋一下。首先,this的指向在函數(shù)定義的時候是確定不了的,只有函數(shù)執(zhí)行的時候才能確定this到底指向誰,實際上this的最終指向的是那個調(diào)用它的對象。那也就是說,this并不是由函數(shù)決定的,而是由最終調(diào)用它的對象決定的。

創(chuàng)新互聯(lián)2013年至今,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項目網(wǎng)站建設(shè)、成都做網(wǎng)站網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元邵東做網(wǎng)站,已為上家服務(wù),為邵東各地企業(yè)和個人服務(wù),聯(lián)系電話:13518219792

例1:

function a(){   

   var user = "追夢子";

   console.log(this.user); //undefined

   console.log(this); //Window

}

a();


這里調(diào)用this的對象是window,a()其實等價于window.a()。


例2:


var o = {
   user:"追夢子",
   fn:function(){
       console.log(this.user);  //追夢子    }
}

o.fn();

這里最終調(diào)用this的是o這個對象,如果按照這個邏輯,最開始對this的解釋就是成立的;然而要看下面的例子,估計又要一頭霧水了。


例3:

var o = {
   a:10,
   b:{
       a:12,
       fn:function(){

           console.log(this.a); //12      

      }

   }
}

o.b.fn();


如果按照最后誰調(diào)取函數(shù)的原則,那么這里打印出來的是10,而不應(yīng)該是12。我的理解是這個this指向調(diào)用這個函數(shù)的離他最近的對象。這里離函數(shù)最近的對象是b,那么this就指代b。


分享文章:js中的this究竟怎么用
網(wǎng)站路徑:http://bm7419.com/article46/ijhoeg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設(shè)計公司、App開發(fā)、ChatGPT、動態(tài)網(wǎng)站、網(wǎng)站制作、品牌網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計公司