欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript事件捕獲機(jī)制【深入分析IE和DOM中的事件模型】

 更新時間:2016年12月15日 10:29:27   作者:小小小小小亮  
這篇文章主要介紹了javascript事件捕獲機(jī)制,結(jié)合實例形式分析了冒泡的原理、事件捕獲、各瀏覽器事件處理機(jī)制與IE和DOM中的事件模型等,需要的朋友可以參考下

本文實例分析了javascript事件捕獲機(jī)制。分享給大家供大家參考,具體如下:

1.什么是事件冒泡?

在排序算法中,我們學(xué)過冒泡排序法,所謂冒泡就是讓底層的東西浮出水面,對于事件冒泡也同樣是如此,

下面我們來看一個例子來說明什么是事件冒泡。

<div>
 <button>測試</button>
</div>
<script>
 $("div").bind("click",function(){alert("div")});
 $("button").bind("click",function(){alert("button"});
</script>

當(dāng)支持事件冒泡時,當(dāng)我們點擊"測試”按鈕時,首先會執(zhí)行的是alert("button"),固名思意:

事件按照從最特定的事件目標(biāo)到最不特定的事件目標(biāo)(document對象)的順序觸發(fā)。

當(dāng)div,button,html根元素都有事件時,事件執(zhí)行的順序為:

button->div->html

2.什么是事件捕獲?

我們再來看事件捕獲,相對于事件捕獲,處理時間的順序與事件冒泡截然相反,同樣:

<div>
 <button>測試</button>
</div>
<script>
 $("div").bind("click",function(){alert("div")});
 $("button").bind("click",function(){alert("button"});
</script>

執(zhí)行這段代碼,首先會alert("div"),其次會alert("button")。我們明確事件捕獲的概念:

事件從最不精確的對象(document 對象)開始觸發(fā),然后到最精確。

同樣的如果button,div,html元素上都有綁定事件,那么事件的實行順序為:

html->div->button

3.各個版本的瀏覽器對事件的處理機(jī)制?

(1)在DOM中,即支持事件冒泡,也支持事件捕獲,在W3C的標(biāo)準(zhǔn)中,認(rèn)為任何事件都是從事件捕獲出發(fā),找到最終的結(jié)點,此后再進(jìn)行冒泡,會到根結(jié)點。

DOM中支持事件綁定的函數(shù)為:

addEventListener("事件名",函數(shù),userCapture);

對于userCapture參數(shù),默認(rèn)為false,支持事件冒泡。
若在userCapture參數(shù),為true時,支持事件捕獲。

(2)對于很多瀏覽器,都支持addEventListener方法,但是IE不支持!

(3) IE中的事件處理機(jī)制,IE中只支持事件冒泡,IE中有一個獨有的事件綁定方法

attachEvent方法,此方法有兩個參數(shù):

attachEvent("事件名","函數(shù)名")

4.如何阻止事件的傳播?

無論是事件冒泡還是事件捕獲都是可以阻止的。

(1)首先在W3C中阻止事件的傳播方法為:stopPropagation(),在IE中,通過設(shè)置

cancelBubble=true;

(2) 如何阻止事件的默認(rèn)行為?在W3C標(biāo)準(zhǔn)中,使用preventDefault方法,在IE中通過設(shè)置

window.event.returnValue = false;

PS:關(guān)于javascript常用事件及相關(guān)說明還可參考本站在線工具:

javascript事件與功能說明大全:
http://tools.jb51.net/table/javascript_event

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript事件相關(guān)操作與技巧大全》、《JavaScript時間與日期操作技巧總結(jié)》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對大家JavaScript程序設(shè)計有所幫助。

相關(guān)文章

最新評論