新的一天工作又开始了!

一、JavaScript事件冒泡及基础应用

一、什么是事件冒泡

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

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

二、事件冒泡有什么作用

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

【集中处理例子】

<div οnclick="eventHandle(event)" id="outSide" style="width:100px; height:100px; background:#000; padding:50px">
<div id="inSide" style="width:100px; height:100px; background:#CCC"></div>
</div>
<script type="text/javascript">
//本例子只在外面盒子定义了处理方法,而这个方法一样可以捕获到子元素点击行为并处理它。假设有成千上万子元素要处理,难道我们要为每个元素加“οnclick="eventHandle(event)"”?显然没有这种集中处理的方法来的简单,同时它的性能也是更高的。
function eventHandle(e)
{
var e=e||window.event;
var obj=e.target||e.srcElement;
alert(obj.id+' was click')
}
</script>

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

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

<div οnclick="outSideWork()" id="outSide" style="width:100px; height:100px; background:#000; padding:50px">
<div οnclick="inSideWork()" id="inSide" style="width:100px; height:100px; background:#CCC"></div>
</div>
<script type="text/javascript">
function outSideWork()
{
alert('My name is outSide,I was working...');
}
function inSideWork()
{
alert('My name is inSide,I was working...');
}
//因为下面程序自动激活单击事件,有些浏览器不允许,所以请单击灰色盒子,从这里开始下命令,这样因为冒泡的原因,黑色大盒子也会收到单击事件,并调用了自己的处理程序。如果还有更多盒子嵌套,一样道理。
/*
function bossOrder()
{
document.getElmentById('inSide').click();
}
bossOrder();
*/
</script>

三、需要注意什么

●事件捕获其实有三种方式,事件冒泡只是其中的一种:(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按钮被点击后会提交表单数据,这种行为无须我们写程序定制。

四、阻止事件冒泡

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

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

<div οnclick="eventHandle(event)" id="outSide" style="width:100px; height:100px; background:#000; padding:50px">
<div id="inSide" style="width:100px; height:100px; background:#CCC"></div>
</div>
<script type="text/javascript">
//本例子只在外面盒子定义了处理方法,而这个方法一样可以捕获到子元素点击行为并处理它。假设有成千上万子元素要处理,难道我们要为每个元素加“οnclick="eventHandle(event)"”?显然没有这种集中处理的方法来的简单,同时它的性能也是更高的。
function eventHandle(e)
{
    var e=e||window.event;
    var obj=e.target||e.srcElement;
    alert(obj.id+' was click')
}
</script>

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

【阻止事件冒泡例子】

<div οnclick="showMsg(this,event)" id="outSide" style="width:100px; height:100px; background:#000; padding:50px">
<div οnclick="showMsg(this,event)" id="inSide" style="width:100px; height:100px; background:#CCC"></div>
</div>
<script type="text/javascript">
//阻止事件冒泡后,你点击灰色盒子,整个过程只弹一次对话框了(注意与默认情况对比)
function showMsg(obj,e)
{
alert(obj.id);
stopBubble(e)
}
//阻止事件冒泡函数
function stopBubble(e)
{
if (e && e.stopPropagation)
e.stopPropagation()
else
window.event.cancelBubble=true
}
</script>

2012年08月24日相关推荐

  1. 【原创】2012年3月24日 单骑至大峪 日志

    先上一张大峪水库全景图 原定于24日骑行至东大的骑行计划,由于诸多方面的原因被取消(响应人员不多,有人临时有事等等,唉,还是我号召力不够呀).自己还是挺想骑行的,不然对不起这么好的天气.于是上古城热线 ...

  2. 轩小宝进城记~~ 2012年3月24日

    出发篇 某妈一直心心念念着要带轩小宝去杭州动物园看狮子老虎,这个小小的愿望却因为某妈的带娃能力不够强的原因一直被滞后,滞后,然后整整滞后了一年多,上上个礼拜,突然在阴雨连绵了N多天以后,突如其来的想去 ...

  3. 2012年08月13日

    转自:http://wjpinrain.blog.51cto.com/1109471/771502 运维中关键技术点解剖: 1 大量高并发网站的设计方案 : 2 高可靠.高可伸缩性网络架构设计: 3 ...

  4. 2012年08月20日

    今天是到公司报到第一天,整体感觉比较轻松.主要如下: 1.办理入职手续,签单到锦业一路总部领取笔记本电脑. 2.由于操作系统没有安装,下午到唐兴数码找剑锋安装操作系统. 3.这样一天的工作就结束了.

  5. 2012年08月22日

    Linux:挂接(mount)命令的使用方法 挂接命令(mount) 首先,介绍一下挂接(mount)命令的使用方法,mount命令参数非常多,这里主要讲一下今天我们要用到的. 命令格式: mount ...

  6. 2012年08月21日

    今天主要安装开发环境,师兄帮忙在AT&T Global Network Client登录,然后安装VirtualBox,和putty.并在VirtualBox上安装操作系统. Putty 随着 ...

  7. 【历史上的今天】10 月 24 日:1024 程序员节;中文维基百科上线;苹果发布 iPad mini

    整理 | 王启隆 透过「历史上的今天」,从过去看未来,从现在亦可以改变未来. 今天是 2021 年 10 月 24 日,大概在 2014 - 2015 年间,中国互联网兴起了一个全新的概念:10 月 ...

  8. 热血篮球维修服务器是怎么回事,热血篮球 12月24日11点维护更新公告

    亲爱的玩家们: <热血篮球>将于2013年12月24日(上午)11:00-13:00进行停服维护,维护期间将无法登录服务器,请各位玩家尽可能在服务器停机之前下线,以免有错误操作可能带来不必 ...

  9. 神经网络贷款风险评估(base on keras and python ) 原创 2017年08月18日 14:35:17 标签: python / 神经网络 / keras 300 用我

    神经网络贷款风险评估(base on keras and python ) 原创 2017年08月18日 14:35:17 标签: python / 神经网络 / keras / 300 编辑 删除 ...

最新文章

  1. iOS_Development~ 添加 / 隐藏 UITabBar 右上角的小红点
  2. 百科知识 .tar.xz文件如何打开
  3. 聊聊并发(八)——Fork/Join框架介绍
  4. Linux 命令之 loginctl -- 查看系统当前登录的用户
  5. CodeForces - 1141CPolycarp Restores Permutation搜索+剪枝
  6. C#json数据的序列化和反序列化(将数据转换为对象或对象集合)
  7. 28 SD配置-主数据-信用管理-定义信贷组
  8. 精细篇Java8强大的stream API接口大全(代码优雅之道)
  9. gorm软删除_删除 |《GORM 中文文档 v1》| Go 技术论坛
  10. 计算机技术与传感技术的关系,现代传感技术与系统课后题及答案.doc
  11. linux下安装mysql
  12. DCDC BUCK芯片外围电路器件计算-包括Cin、Cout、L、f、cFF、等输出电容、电感计算、补偿电路计算
  13. 重构kz-admin
  14. 计算机与测控技术专业就业方向,测控技术与仪器专业就业前景与方向(五篇)
  15. 小程序API的Promise化
  16. 基于IIC和SPI协议的OLED显示(STM32)
  17. 【零基础深度学习教程第二课:深度学习进阶之神经网络的训练】
  18. 【项目管理】项目成本管理
  19. 17 追悔:回到过去,你也不能改变命运
  20. android 特效相机实现,安卓特效相机(三) OpenGL ES 特效渲染

热门文章

  1. DreamCamera2常见预览问题修改方案
  2. php文件上传实验总结,PHP文件上传一些小收获
  3. 华为S系列交换机配置802.1x+MAC认证,python简洁配置版
  4. Bootstrap学习笔记03
  5. 关于Unity使用ArcGisMapsSDK这码事
  6. JAVA基础 装箱类型
  7. 【MySQL】数据库服务器硬件优化与实战详解(调优篇)(实战篇)(MySQL专栏启动)
  8. 2018年河南专升本管理学真题
  9. SVG阴影、滤镜、渐变
  10. Skype语音测试,会议电话Skype音频测试