第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

javascript運(yùn)行上下文 問(wèn)題

javascript運(yùn)行上下文 問(wèn)題

搖曳的薔薇 2019-04-19 16:29:22
varelement=document.getElementById('element');varuser={firstname:'Wilson',greeting:function(){alert('Mynameis'+this.firstname);}};//Attachuser.greetingasacallbackelement.addEventListener('click',user.greeting);//alert=>'Mynameisundefined'為什么運(yùn)行的時(shí)候,拿不到上下文的值firstname的值
查看完整描述

2 回答

?
慕斯王

TA貢獻(xiàn)1864條經(jīng)驗(yàn) 獲得超2個(gè)贊

這不是上下文件的問(wèn)題,是this的問(wèn)題。
像下面這么改下就對(duì)了:
element.addEventListener('click',user.greeting.bind(user));
                            
查看完整回答
反對(duì) 回復(fù) 2019-04-19
?
隔江千里

TA貢獻(xiàn)1906條經(jīng)驗(yàn) 獲得超10個(gè)贊

@邊城狂人已經(jīng)把問(wèn)題解釋清楚了,只是做點(diǎn)補(bǔ)充說(shuō)明。
問(wèn)題是怎么出現(xiàn)的
JS中的this只與函數(shù)調(diào)用方式有關(guān),與定義時(shí)的上下文,函數(shù)作用域,都無(wú)關(guān)。有如下情況:
user.greeting()//this-->user
varhandler=user.greeting;
handler()//this-->window
當(dāng)程序執(zhí)行到
element.addEventListener('click',user.greeting);
user.greeting作為addEventListener的第二個(gè)參數(shù),假設(shè)這個(gè)參數(shù)就叫handler??梢韵胂螅赼ddEventListener的內(nèi)部,進(jìn)行了類似
varhandler=user.greeting;//這步在傳遞參數(shù)時(shí)完成
handler()//this-->window
的過(guò)程,this的指向就發(fā)生了改變。
如何修復(fù)
this的指向只與函數(shù)調(diào)用方式有關(guān),函數(shù)調(diào)用方式一共四種:
func();
obj.func();
func.apply/call();
newfunc();
要修復(fù)這個(gè)問(wèn)題,需要用到apply/call這種調(diào)用方式。我們可以想象bind是這樣一個(gè)函數(shù):
functionbind(func,target){
returnfunction(){
func.apply(target,arguments);
}
}
Function.prototype['bind']=function(target){
returnbind(this,target);
}
這樣,就可以使用element.addEventListener('click',user.greeting.bind(user));來(lái)解決這個(gè)問(wèn)題了。當(dāng)然,這里的bind是非常簡(jiǎn)化、不可用的,比如可以看到bindreturn的函數(shù)已經(jīng)不是原函數(shù)了,為了保持一致性應(yīng)該綁定原型鏈。這一系列完整的操作在MDN文檔中都可以看到。
                            
查看完整回答
反對(duì) 回復(fù) 2019-04-19
  • 2 回答
  • 0 關(guān)注
  • 382 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)