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

為了賬號安全,請及時綁定郵箱和手機立即綁定

this和e.target區別,求教

我的理解,this永遠指向事件綁定的對象,e.target永遠指向當前觸發事件的對象,

比如下面例子,this永遠指向ul,e.target可能指向ul,可能指向li,對嗎?

<ul>

<li>111</li>

<li>222</li>

<li>333</li>

</ul>

$(ul).on('click',function(e){

alert($(this).text());

alert(e.target.textContent);

$

})

正在回答

2 回答

可以這樣理解吧,e.target指向當前點擊的DOM元素,點擊哪個li就是哪個li,點擊ul就是ul.因為js是會冒泡的,所以點擊li的時候,this會變成ul.

0 回復 有任何疑惑可以回復我~

this指觸發事件的元素,無論你鼠標點擊在什么位置,觸發事件的元素都是ul,所以this指ul,但是e.target指鼠標的焦點元素,如果你點擊到了ul內部的li,則e.target指的就是li,但是如果你點擊的是ul其他的非li部分,則this和e.target是一樣的。

如果不是通過冒泡產生的事件,則this和e.target沒有區別。

2 回復 有任何疑惑可以回復我~
#1

金剛無敵葫蘆娃

不是這樣吧,this指向的是監聽事件的元素,e.target指向觸發事件的元素, 事件可以由ul觸發,也可以由li觸發,所以e.target可能是ul,也可能是li; 但無論是ul觸發還是li觸發,都是由ul監聽捕獲的,所以this指向ul
2020-04-11 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

this和e.target區別,求教

我要回答 關注問題
微信客服

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

幫助反饋 APP下載

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

公眾號

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