第七色在线视频,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-14 11:28:42
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 回答

?
尚方寶劍之說(shuō)

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

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

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

問(wèn)題是怎么出現(xiàn)的JS中的this只與函數(shù)調(diào)用方式有關(guān),與定義時(shí)的上下文,函數(shù)作用域,都無(wú)關(guān)。有如下情況:user.greeting()//this-->uservarhandler=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-14
  • 2 回答
  • 0 關(guān)注
  • 322 瀏覽
慕課專欄
更多

添加回答

舉報(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)