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

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

JS代理事件綁定

JS代理事件綁定

慕圣9424722 2017-10-15 20:21:37
<div?id="div"> <a?class="aa"??id="btn1"?class="btn"?href="www.baidu.com">1</a> <a?class="aa"?id="btn2"?class="btn"?href="www.baidu.com">2</a> <a?class="aa"?id="btn3"?class="btn"?href="www.baidu.com">3</a> <a?class="aa"??id="btn4"?class="btn"??href="www.baidu.com">4</a> </div> var?div?=?document.getElementById('div') function?bindEvent(elem,type,selector,fn){ if(fn?==?null){ fn?=?selector; selector?=?null; } elem.addEventListener(type,function(e){ var?target?=?e.target; e.preventDefault() if(selector?=?null){ fn(e) }else{ if(target.matches(selector)){ fn.call(target,e) } } }) } bindevent(div,?'click',?'a',?function(e)?{ alert(this.innerHTML) }) ??????????????????????//部分代碼修改后 ????????????elem.addEventListener(type,?function(e)?{ ???????????????var?target?=?e.target; ???????????????e.preventDefault() ??????if(selector)?{ ???if(target.matches(selector))?{? fn.call(target,?e) ??} }?else?{ fn(e) } }) 如上代碼,之前沒有效果,后來只是將判斷的順序變了下,就好了,這是什么原因?求大神指點
查看完整描述

2 回答

已采納
?
慕spring

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

selector?=?null ? 改為 ? ?selector?== null


查看完整回答
反對 回復 2017-10-16
?
qq_莫非

TA貢獻257條經驗 獲得超93個贊

因為代碼的執行是有順序的,你這個觸發事件然后根據id查找執行代碼,你前面沒有出現過id為。。。的代碼,就找不到,就不能執行,要把id綁定的事件放在后面才能有效果

getElementById,就是根據id查找,如果你id=“”的代碼后于這個執行,他就找不到

查看完整回答
反對 回復 2017-10-16
  • 慕圣9424722
    慕圣9424722
    沒看懂~ 即使不寫var div = document.getElementById('div'),JS也可以獲取ID元素,只是這樣寫一下更規范,瀏覽器兼容性更高, 可能正確答案就像樓上說的,少了個“=”~
  • 2 回答
  • 0 關注
  • 2050 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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