JavaScript事件冒泡简介及应用

1、什么是事件冒泡

在一个对象上触发某类事件(好比单击onclick事件),若是此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,若是没有定义此事件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象传播,从里到外,直至它被处理(父级对象全部同类事件都将被激活),或者它到达了对象层次的最顶层,即document对象(有些浏览器是window)。javascript

打个比方说:你在地方法院要上诉一件案子,若是地方没有处理此类案件的法院,地方相关部门会帮你继续往上级法院上诉,好比从市级到省级,直至到中央法院,最终使你的案件得以处理。java

2、事件冒泡有什么做用

(1)事件冒泡容许多个操做被集中处理(把事件处理器添加到一个父级元素上,避免把事件处理器添加到多个子级元素上),它还可让你在对象层的不一样级别捕获事件程序员

【集中处理例子】浏览器

按 Ctrl+C 复制代码ide

按 Ctrl+C 复制代码google

(2)让不一样的对象同时捕获同一事件,并调用本身的专属处理程序作本身的事情,就像老板一下命令,各自员工作本身岗位上的工做去了。url

【同时捕获同一事件例子】spa

按 Ctrl+C 复制代码设计

按 Ctrl+C 复制代码调试

3、须要注意什么

●事件捕获其实有三种方式,事件冒泡只是其中的一种:(1)IE从里到外(inside→outside)的冒泡型事件。(2)Netscape4.0从外到里(outside→inside)的捕获型事件。(3)DOM事件流,先从外到里,再从里到外回到原点(outside→inside→outside)的事件捕获方法(彷佛对象将触发两次事件处理,这有什么做用?鄙人不懂!)。

●不是全部的事件都能冒泡。如下事件不冒泡:blur、focus、load、unload。

●事件捕获方式在不一样浏览器,甚至同种浏览器的不一样版本中是有所区别的。如Netscape4.0采用捕获型事件解决方案,其它多数浏览器则支持冒泡型事件解决方案,另外DOM事件流还支持文本节点事件冒泡。

●事件捕获到达顶层的目标在不一样浏览器或不一样浏览器版本也是有区别的。在IE6中HTML是接收事件冒泡的,另外大部分浏览器将冒泡延续到window对象,即……body→documen→window。

●阻止冒泡并不能阻止对象默认行为。好比submit按钮被点击后会提交表单数据,这种行为无须咱们写程序定制。

4、阻止事件冒泡

一般状况下咱们都是一步到位,明确本身的事件触发源,并不但愿浏览器自做聪明、漫无目的地去帮咱们找合适的事件处理程序,即咱们明确最精准目标,这种状况下咱们不须要事件冒泡。另外经过对事件冒泡的理解,咱们知道程序将作多较多额外的事情,这必然增大程序开销。还有一个重要的问题是:事件冒泡处理可能会激活咱们原本不想激活的事件,致使程序错乱,甚至无从下手调试,这常成为对事件冒泡不熟悉程序员的棘手问题。因此必要时,咱们要阻止事件冒泡。

【不想激活的事件被激活例子】

复制代码

<div onclick="openWin('http://www.baidu.com')" id="outSide" style="width:100px; height:100px; background:#000; padding:50px">
<div onclick="openWin('http://www.google.com')" id="inSide" style="width:100px; height:100px; background:#CCC"></div>
</div>

<script type="text/javascript">
//本例你实际但愿点击灰色盒子打开google首页,而点击黑色盒子打开baidu首页,但结果你点击灰色盒子的时候,倒是同时打开了两个网页。其实在实际设计中较少遇到此问题,你可能会想若是我在页面不一样DOM深处安置了不一样的按钮或连接,深层处的事件触发会不会波及顶层的按钮呢?不会,由于按钮不能造成嵌套关系。
function openWin(url)
{
    window.open(url);
}
</script>

复制代码

下面是本人在网上抄的一个方法,把这个方法放在精准目标对象处理程序结尾,本事件触发处理结束后,事件将不在进行冒泡处理。

【阻止事件冒泡例子】

按 Ctrl+C 复制代码

按 Ctrl+C 复制代码

相关文章
相关标签/搜索