addEventListener和on的區別

2021-08-20 13:24:25 字數 1379 閱讀 9325

為什麼需要addeventlistener?

先來看乙個片段:

html**

追夢子用on的**

1 window.onload = function()

6 box.onclick = function()

10 }

執行結果:「我是box2」

看到了吧,第二個onclick把第乙個onclick給覆蓋了,雖然大部分情況我們用on就可以完成我們想要的結果,但是有時我們又需要執行多個相同的事件,很明顯如果用on完成不了我們想要的,那不用猜,你們肯定知道了,對!addeventlistener可以多次繫結同乙個事件並且不會覆蓋上乙個事件。

用addeventlistener的**

1 window.onload = function())

6 box.addeventlistener("click",function())

9 }    執行結果:我是box1

我是box2

addeventlistenert方法第乙個引數填寫事件名,注意不需要寫on,第二個引數可以是乙個函式,第三個引數是指在冒泡階段還是捕獲階段處理事件處理程式,如果為true代表捕獲階段處理,如果是false代表冒泡階段處理,第三個引數可以省略,大多數情況也不需要用到第三個引數,不寫第三個引數預設false

第三個引數的使用

有時候的情況是這樣的

如果我給box加click事件,如果我直接單擊box沒有什麼問題,但是如果我單擊的是child元素,那麼它是怎麼樣執行的?(執行順序)

1 box.addeventlistener("click",function())

4 5 child.addeventlistener("click",function())

執行的結果:

child

box

也就是說,預設情況事件是按照事件冒泡的執行順序進行的。

如果第三個引數寫的是true,則按照事件捕獲的執行順序進行的。

1 box.addeventlistener("click",function(),true)

4 5 child.addeventlistener("click",function())

執行的結果:

boxchild

事件冒泡執行過程:

從最具體的的元素(你單擊的那個元素)開始向上開始冒泡,拿我們上面的案例講它的順序是:child->box

事件捕獲執行過程:

從最不具體的元素(最外面的那個盒子)開始向裡面冒泡,拿我們上面的案例講它的順序是:box->child

addEventListener和on的區別

為什麼需要addeventlistener?先來看乙個片段 html 追夢子 用on的 1 window.onload function 6 box.onclick function 10 執行結果 我是box2 看到了吧,第二個onclick把第乙個onclick給覆蓋了,雖然大部分情況我們用on...

記錄addEventListener的相關知識

1 addeventlistener的引數 有三個引數 第乙個引數表示事件名稱 不包括on,比如 click 第二個引數表示要接收事件處理的函式,第三個引數為usecapture 記錄一下第三個引數,有兩種方式,可以設定成boolean型別 usecapture 或者object型別 options...

addEventListener 的三個引數

addeventlistener 有三個引數 第乙個引數表示事件名稱 不含 on,如 click 第二個引數表示要接收事件處理的函式 第三個引數為 usecapture,本文就講解它。outdiv middlediv indiv 請在此點選滑鼠。info 上述是我們測試的 根據 info 的顯示來確...