摘要:見下圖更直觀在事件流中,事件的目標(biāo)在捕獲階段不會(huì)接受到事件,這意味著在捕獲階段,事件從到后就停止了。下一個(gè)階段是目標(biāo)階段,于是事件在上發(fā)生,并在事件處理中被看成是冒泡階段的一部分,然后,冒泡階段發(fā)生,事件又傳回。
CONTENTS
DOM事件流
事件冒泡
阻止冒泡
事件捕獲
事件委托
DOM事件流1.什么是事件流?
事件流所描述的是從頁面中接受事件的順序
2.DOM事件流的三個(gè)階段?
事件流包括三個(gè)階段:事件捕獲階段、處于目標(biāo)階段、事件冒泡階段
3.DOM事件流三個(gè)階段的執(zhí)行順序?
首先發(fā)生的事件捕獲,為截取事件提供機(jī)會(huì),然后是目標(biāo)接受事件,最后是事件冒泡階段,所以可以在最后一個(gè)階段對(duì)事件作出響應(yīng)。見下圖更直觀:
在dom事件流中,事件的目標(biāo)在捕獲階段不會(huì)接受到事件,這意味著在捕獲階段,事件從 document? 到? div 后就停止了。下一個(gè)階段是目標(biāo)階段,于是事件在 div 上發(fā)生,并在事件處理中被看成是冒泡階段的一部分, 然后,冒泡階段發(fā)生,事件又傳回document。
事件冒泡1.什么是事件冒泡?
當(dāng)事件發(fā)生后,這個(gè)事件就要開始傳播(從里向外或者從外向里)
2.為什么要傳播?
? ? ? ? 因?yàn)槭录幢旧恚赡埽┎]有處理事件的能力,即處理事件的函數(shù)(方法)并未綁定在該事件源上。例如我們點(diǎn)擊一個(gè)按鈕時(shí),就會(huì)產(chǎn)生一個(gè)click事件,但這個(gè)按鈕本身可能不能處理這個(gè)事件,事件必須從這個(gè)按鈕傳播出去,從而到達(dá)能夠處理這個(gè)事件的代碼中(例如我們給按鈕的onclick屬性賦一個(gè)函數(shù)的名字,就是讓這個(gè)函數(shù)去處理該按鈕的click事件),或者按鈕的父級(jí)綁定有事件函數(shù),當(dāng)該點(diǎn)擊事件發(fā)生在按鈕上,按鈕本身并無處理事件函數(shù),則傳播到父級(jí)去處理。
小案例代碼如下:
?Document ?
當(dāng)我們點(diǎn)擊按鈕button時(shí),事件時(shí)這樣傳播的:
(1) button
(2) div
(3) body
(4) html
(5) document
阻止冒泡1.為什么要阻止冒泡?
例如:document上有A事件,div有B事件,div里面的span有C事件,如果不給span和div加阻止事件冒泡的話,點(diǎn)擊span時(shí)就會(huì)觸發(fā)到div的B事件、document的A事件,當(dāng)點(diǎn)擊span時(shí)不想觸發(fā)div和document的事件就要加上阻止事件冒泡,div也是一樣的道理,如果我們不想讓點(diǎn)擊某個(gè)事件時(shí)父級(jí)受到影響,這時(shí)就應(yīng)阻止冒泡。
eg:不加阻止冒泡事件,代碼如下:
css代碼:
? ?
js+html代碼:
??
效果如下:
如圖可以看出當(dāng)點(diǎn)擊? box1? 時(shí),只會(huì)提示‘您點(diǎn)擊了box1’? 而點(diǎn)擊? ?box2? 時(shí),竟然輸出了兩句提示,如果我們不想要這種效果,我們只想要在點(diǎn)擊了哪個(gè)按鈕后就執(zhí)行該按鈕的命令,也就是說阻止冒泡。
下面給出上述小案例的阻止冒泡方法:一句代碼搞定,改變 box2? 的觸發(fā)事件,代碼如下:
? box2.onclick = function(e){ console.log("您點(diǎn)擊了box2"); e.stopPropagation(); }
效果圖如下:這樣就實(shí)現(xiàn)阻止冒泡
2.阻止冒泡的方法。
①event.stopPropagation()方法?(這個(gè)方法小編在上面已經(jīng)給出了例子,這里就不在給出具體的例子)
這是阻止事件的冒泡方法,不讓事件向documen上蔓延,但是默認(rèn)事件仍然會(huì)執(zhí)行,當(dāng)你調(diào)用這個(gè)方法的時(shí)候,如果點(diǎn)擊一個(gè)連接,這個(gè)連接仍然會(huì)被打開,
②event.preventDefault()方法
這是阻止默認(rèn)事件的方法,調(diào)用此方法是,連接不會(huì)被打開,但是會(huì)發(fā)生冒泡,冒泡會(huì)傳遞到上一層的父元素;
下面給大家一個(gè)小例子:看圖說話,在下面的空白處,無論我怎么點(diǎn)擊右鍵,無論在什么位置點(diǎn)擊,都會(huì)出現(xiàn)默認(rèn)的東西,如果我們不想要這種默認(rèn)的東西怎么辦呢?繼續(xù)看圖下面的案例,馬上帶你飛,走起-------
eg:阻止瀏覽器右鍵默認(rèn)事件
css代碼:
?html+js代碼:
- 刷新
- 刪除
- 命名
效果如下:
③?return false(這里的例子就不贅述了,有心的小伙伴可以動(dòng)手試試)
這個(gè)方法比較暴力,他會(huì)同時(shí)阻止事件冒泡也會(huì)阻止默認(rèn)事件;寫上此代碼,連接不會(huì)被打開,事件也不會(huì)傳遞到上一層的父元素;可以理解為return false就等于同時(shí)調(diào)用了event.stopPropagation()和event.preventDefault()
事件捕獲事件捕獲和事件冒泡是剛好相反的,事件捕獲是指不太具體的節(jié)點(diǎn)應(yīng)該更早的接收到事件,而最具體的節(jié)點(diǎn)應(yīng)該最后接收到事件
案例走起:
css代碼:
? ?
html+js代碼:
??
動(dòng)態(tài)效果如下:
當(dāng)我點(diǎn)擊最里面的 box3 時(shí),我們可以看到最外層的事件先被觸發(fā),最后才是我們點(diǎn)擊的 box3? 事件被觸發(fā),這便是事件捕獲。?事件委托
1.什么是事件委托?
事件委托又名事件代理,JavaScript高級(jí)程序設(shè)計(jì)上講:事件委托就是利用事件冒泡,只指定一個(gè)事件處理程序,就可以管理某一類型的所有事件。
官方語言太抽象,其實(shí)就是一個(gè)生活中的原理--------班級(jí)收作業(yè)
收作業(yè)有兩種方法:一是誰寫完了自己去交個(gè)老師。二是寫完了統(tǒng)一交給班長,讓班長交給老師,現(xiàn)實(shí)當(dāng)中,我們大都采用第二種方法。這就可以理解為委托,無論是誰交給老師,目的只有一個(gè)就是作業(yè)能夠正常上交。
2.為什么要用委托?
一般來說,dom需要有事件處理程序,我們都會(huì)直接給它設(shè)事件處理程序就好了,那如果是很多的dom需要添加事件處理呢?比如我們有100個(gè)li,每個(gè)li都有相同的click點(diǎn)擊事件,可能我們會(huì)用for循環(huán)的方法,來遍歷所有的li,然后給它們添加事件,那這么做會(huì)存在什么影響呢?在JavaScript中,添加到頁面上的事件處理程序數(shù)量將直接關(guān)系到頁面的整體運(yùn)行性能,因?yàn)樾枰粩嗟呐cdom節(jié)點(diǎn)進(jìn)行交互,訪問dom的次數(shù)越多,引起瀏覽器重繪與重排的次數(shù)也就越多,就會(huì)延長整個(gè)頁面的交互就緒時(shí)間,這就是為什么性能優(yōu)化的主要思想之一就是減少DOM操作的原因;如果要用事件委托,就會(huì)將所有的操作放到j(luò)s程序里面,與dom的操作就只需要交互一次,這樣就能大大的減少與dom的交互次數(shù),提高性能;
每個(gè)函數(shù)都是一個(gè)對(duì)象,是對(duì)象就會(huì)占用內(nèi)存,對(duì)象越多,內(nèi)存占用率就越大,自然性能就越差了(內(nèi)存不夠用,是硬傷,哈哈),比如上面的100個(gè)li,就要占用100個(gè)內(nèi)存空間,如果是1000個(gè),10000個(gè)呢,那只能說呵呵了,如果用事件委托,那么我們就可以只對(duì)它的父級(jí)(如果只有一個(gè)父級(jí))這一個(gè)對(duì)象進(jìn)行操作,這樣我們就需要一個(gè)內(nèi)存空間就夠了,是不是省了很多,自然性能就會(huì)更好。
3.事件委托原理
事件委托是利用事件的冒泡原理來實(shí)現(xiàn)的,何為事件冒泡呢?就是事件從最深的節(jié)點(diǎn)開始,然后逐步向上傳播事件,舉個(gè)例子:頁面上有這么一個(gè)節(jié)點(diǎn)樹,div>ul>li>a;比如給最里面的a加一個(gè)click點(diǎn)擊事件,那么這個(gè)事件就會(huì)一層一層的往外執(zhí)行,執(zhí)行順序a>li>ul>div,有這樣一個(gè)機(jī)制,那么我們給最外面的div加點(diǎn)擊事件,那么里面的ul,li,a做點(diǎn)擊事件的時(shí)候,都會(huì)冒泡到最外層的div上,所以都會(huì)觸發(fā),這就是事件委托,委托它們父級(jí)代為執(zhí)行事件。
4.事件委托怎么實(shí)現(xiàn)?
小案例繼續(xù)走:
代碼如下:
效果見下圖:
當(dāng)用事件委托的時(shí)候,根本就不需要去遍歷元素的子節(jié)點(diǎn),只需要給父級(jí)元素添加事件就好了,其他的都是在js里面的執(zhí)行,這樣可以大大的減少dom操作,這才是事件委托的精髓所在。
5.委托總結(jié)
那什么樣的事件可以用事件委托,什么樣的事件不可以用呢?適合用事件委托的事件:click,mousedown,mouseup,keydown,keyup,keypress。
值得注意的是,mouseover和mouseout雖然也有事件冒泡,但是處理它們的時(shí)候需要特別的注意,因?yàn)樾枰?jīng)常計(jì)算它們的位置,處理起來不太容易。
不適合的就有很多了,舉個(gè)例子,mousemove,每次都要計(jì)算它的位置,非常不好把控,在不如說focus,blur之類的,本身就沒用冒泡的特性,自然就不能用事件委托了。
好了,今天就到這里,下次我想介紹一下事件綁定,歡迎大家關(guān)注和閱讀,以上純屬個(gè)人見解,如有不對(duì)的地方,萬望指正,不勝感謝!
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/52673.html
摘要:事件流指的是從頁面接收事件的順序。級(jí)事件規(guī)定方法的第三個(gè)參數(shù)設(shè)為,表示事件在捕獲階段觸發(fā)。目前支持事件捕獲流的瀏覽器有,,,,。事件流根據(jù)級(jí)事件規(guī)定,事件流應(yīng)該包括三個(gè)階段,事件捕獲階段,處于目標(biāo)階段和事件冒泡階段。 什么是事件?(敲黑板) 事件,就是文檔或?yàn)g覽器窗口發(fā)生的一些特定的交互瞬間。(by 《JavaScript高級(jí)程序設(shè)計(jì)》)比如鼠標(biāo)點(diǎn)擊,雙擊,滾動(dòng)條滑動(dòng)... 什么是事件...
摘要:可以使用偵聽器或處理程序來預(yù)訂事件,以便事件發(fā)生時(shí)執(zhí)行相應(yīng)的代碼。響應(yīng)某個(gè)事件的函數(shù)稱為事件處理程序或事件偵聽器??梢詣h除通過級(jí)方法指定的事件處理程序。 JavaScript和HTML之間的交互是通過事件實(shí)現(xiàn)的。 事件:文檔或?yàn)g覽器窗口中發(fā)生的一些特定的交互瞬間。 可以使用偵聽器(或處理程序來預(yù)訂事件),以便事件發(fā)生時(shí)執(zhí)行相應(yīng)的代碼。 1. 事件流 事件流:從頁面中接收事件的順序。 ...
摘要:捕獲型事件流事件的傳播是從最不特定的事件目標(biāo)到最特定的事件目標(biāo)。鼠標(biāo)移入元素范圍內(nèi)觸發(fā),該事件不冒泡,即鼠標(biāo)移到其后代元素上時(shí)不會(huì)觸發(fā)。 事件通常與函數(shù)配合使用,這樣就可以通過發(fā)生的事件來驅(qū)動(dòng)函數(shù)執(zhí)行,事件是可以被 JavaScript 偵測(cè)到的行為 綁定事件 首先我們要先綁定事件 綁定事件有三種 1)在DOM元素中直接綁定,我們可以在DOM元素上綁定onclick、onmouseov...
摘要:捕獲型事件流事件的傳播是從最不特定的事件目標(biāo)到最特定的事件目標(biāo)。鼠標(biāo)移入元素范圍內(nèi)觸發(fā),該事件不冒泡,即鼠標(biāo)移到其后代元素上時(shí)不會(huì)觸發(fā)。 事件通常與函數(shù)配合使用,這樣就可以通過發(fā)生的事件來驅(qū)動(dòng)函數(shù)執(zhí)行,事件是可以被 JavaScript 偵測(cè)到的行為 綁定事件 首先我們要先綁定事件 綁定事件有三種 1)在DOM元素中直接綁定,我們可以在DOM元素上綁定onclick、onmouseov...
摘要:事件流級(jí)事件規(guī)定的事件流包括三個(gè)階段事件捕獲階段處于目標(biāo)階段和事件冒泡階段。事件處理程序的名字以開頭,如等。如使用級(jí)方法指定的事件處理程序被認(rèn)為是元素的方法。 事件流 事件流描述的是從頁面中接收事件的順序。IE的事件流是事件冒泡流,而Netscape Communicator的事件流是事件捕獲流。 事件冒泡 即事件開始時(shí)由最具體的元素接收,然后逐級(jí)向上傳播到較為不具體的節(jié)點(diǎn)。如: ...
閱讀 3225·2021-11-24 09:39
閱讀 2950·2021-11-23 09:51
閱讀 903·2021-11-18 10:07
閱讀 3553·2021-10-11 10:57
閱讀 2765·2021-10-08 10:04
閱讀 3013·2021-09-26 10:11
閱讀 1061·2021-09-23 11:21
閱讀 2805·2019-08-29 17:28