亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

js中,addEventListener時用的是匿名函數,應該怎么移除事件?

js中,addEventListener時用的是匿名函數,應該怎么移除事件?

慕桂英546537 2019-04-16 20:27:08
像下面init()里面那樣添加的事件,應該怎么移除?如下的例子是移除不了的,請問還有別的方法嗎?functioninit(){aabtn.addEventListener("click",function(e){aa()});//aabtn是一個div}vari=0;functionaa(){tex.innerHTML=i++;//tex也是一個divaabtn.removeEventListener("click",arguments.callee);//這樣的寫法是不行的,請問還有別的寫法嗎?}
查看完整描述

2 回答

?
慕標5832272

TA貢獻1966條經驗 獲得超4個贊

啊哈哈哈,我知道問題出在哪了,也知道arguments.callee到底是什么了!原來在函數內,arguments.callee是指本函數,也就是函數自身,所以以下會在控制臺輸出函數aa(toString後也就是函數的代碼)。
(functionaa(){
console.log(arguments.callee);
}());
而我要的函數不是這個,而是綁定到click的函數,所以代碼應該改成這樣:
vari=0;
functioninit(){
aabtn.addEventListener("click",function(e){aa(arguments.callee);});
}
functionaa(fun){
tex.innerHTML=i++;
aabtn.removeEventListener("click",fun);
}
                            
查看完整回答
反對 回復 2019-04-16
  • 2 回答
  • 0 關注
  • 630 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號