溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

js中的this究竟怎么用

發(fā)布時(shí)間:2020-07-28 16:06:33 來源:網(wǎng)絡(luò) 閱讀:213 作者:尼羲 欄目:web開發(fā)

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


例1:

function a(){   

   var user = "追夢子";

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

   console.log(this); //Window

}

a();


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


例2:


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

o.fn();

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


例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。我的理解是這個(gè)this指向調(diào)用這個(gè)函數(shù)的離他最近的對(duì)象。這里離函數(shù)最近的對(duì)象是b,那么this就指代b。




向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI