Js事件傳播流程, 事件阻止

js事件傳播流程主要分三個(gè)階段:事件捕獲階段、處于目標(biāo)階段、事件冒泡階段。   

在我們平常用的addEventListener方法中,一般只會(huì)用到兩個(gè)參數(shù),一個(gè)是需要綁定的事件,另一個(gè)是觸發(fā)事件后要執(zhí)行的函數(shù),然而,addEventListener還可以傳入第三個(gè)參數(shù),第三個(gè)參數(shù)默認(rèn)值是false,表示在事件冒泡階段調(diào)用事件處理函數(shù);如果參數(shù)為true,則表示在事件捕獲階段調(diào)用處理函數(shù)。

(1).捕獲階段:事件從根節(jié)點(diǎn)流向目標(biāo)節(jié)點(diǎn),途中流經(jīng)各個(gè)DOM節(jié)點(diǎn),在各個(gè)節(jié)點(diǎn)上觸發(fā)捕獲事件,直到達(dá)到目標(biāo)節(jié)點(diǎn)。

(2).目標(biāo)(target)階段:在此階段中,事件傳導(dǎo)到目標(biāo)節(jié)點(diǎn)。瀏覽器在查找到已經(jīng)指定給目標(biāo)事件的監(jiān)聽器后,就會(huì)運(yùn)行該監(jiān)聽器。

?

(3).事件冒泡:?當(dāng)為多個(gè)嵌套的元素設(shè)置了相同的事件處理程序,它們將觸發(fā)事件冒泡機(jī)制。在事件冒泡中,最內(nèi)部的元素將首先觸發(fā)其事件,然后是棧內(nèi)的下一個(gè)元素觸發(fā)該事件,以此類推,直到到達(dá)最外面的元素。如果把事件處理程序指定給所有的元素,那么這些事件將依次觸發(fā)。

阻止默認(rèn)事件

1、在javescript中,return flase可以阻止默認(rèn)事件,但必須加在onmousedown事件中,down的事兒干完了,再加return flase。

2、在自定義函數(shù)addEvent中,return flase會(huì)失效,請使用事件對象來進(jìn)行阻止。ev.preventDefault();//阻止默認(rèn)事件。

3、在低版本的IE中這些都不好使,需在onmousemove事件中調(diào)用obj.setCapture&&obj.setCapture();并且在onmouseup事件中清除obj.releaseCapture&&obj.releaseCapture();

阻止事件冒泡

事件冒泡:

1、當(dāng)子級(jí)的事件觸發(fā)時(shí),其父級(jí)的事件也被觸發(fā)了。

2、冒泡跟它們在頁面中的顯示位置無關(guān),只要在html結(jié)構(gòu)中兩者是屬于父子關(guān)系,就存在事件冒泡。

3、阻止事件冒泡必須加在子級(jí)的身上。通過事件對象進(jìn)行阻止。ev.cancelBubble=true;

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • ??JavaScript 與 HTML 之間的交互是通過事件實(shí)現(xiàn)的。 ??事件,就是文檔或?yàn)g覽器窗口中發(fā)生的一些特...
    霜天曉閱讀 3,715評論 1 11
  • JavaScript 與 HTML 之間的交互是通過事件實(shí)現(xiàn)的。事件,就是文檔或?yàn)g覽器窗口中發(fā)生的一些特定的交互瞬...
    LemonnYan閱讀 745評論 0 4
  • Dom事件 事件是一種異步編程的實(shí)現(xiàn)方式,本質(zhì)上是程序各個(gè)組成部分之間的通信。DOM支持大量的事件 (一) Eve...
    woow_wu7閱讀 1,899評論 0 1
  • 一、概述 事件流:事件流描述的是從頁面中接收事件的順序。 DOM事件流傳播的三個(gè)過程: 事件捕獲階段 ——》 處于...
    Fairy_妍閱讀 1,535評論 0 2
  • 事件流 Click Me 冒泡型事件:事件按照從最特定的事件目標(biāo)到最不特定的事件目標(biāo)的順序觸發(fā)。觸發(fā)的順序是:di...
    醋留香閱讀 968評論 0 1

友情鏈接更多精彩內(nèi)容