在一些传统的小型WEB应用开发过程中,JavaScript通常只是拿来做表单验证而以,所以你很少会遇到因为JavaScript事件冒泡而影响功能的实现情况,又或者事件冒泡对最终实现效果影响不大,可忽略。然而,在今天一些大型的WEB交互项目中,比如大型的WebGame项目,JavaScript事件冒泡影响是值得重视的。本文通过一个简单的例子来讲解JavaScript事件冒泡及使用注意事项。

如果你对JavaScript事件冒泡还没有什么印象,不妨先看看我之前写的一篇博客《JavaScript事件冒泡简介及应用》。本文讲究实用,不在对JavaScript事件冒泡基础知识进行过多的阐述。

在文章开始之前,现在先看看下面这样一个需求:下面HTML假设描述的是一个WebGame项目包裹栏(玩过网游的人应该知道什么是包裹栏或物品栏)的外框架,拖动这个包裹标题栏可以拖动这个包裹到页面上任何位置,而点击标题栏右侧的“×”关闭按钮可以关闭这个包裹栏的显示。你通过观察HTML结构,可以发现那个关闭按钮其实是一个A链接,而且是作为标题栏H5的子元素存在。要想拖动一个元素,我们会想到向拖动的句柄元素注册mousedown事件,而点击或“单击”关闭按钮就关闭这个包裹。根据这个需求,我们很快得到下面这样的代码。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>JavaScript事件冒泡实例一</title>
<style type="text/css">
#box {width:200px; height:100px; border:2px solid blue}
#box h5 {margin:0; padding:2px 5px; font-size:18px; text-align:right; background:blue; cursor:move}
#box h5 a {text-decoration:none; color:#FFF}
</style>
</head>

<body>
<div id="box">
<h5 onmousedown="startDrag();"><a onclick="closeBox();" href="javascript:void(0);">×</a></h5>
<div id="testInfo"></div>
</div>
<script type="text/javascript">
function startDrag()
{
    document.getElementById('testInfo').innerHTML += 'startDrag<br/>';
}
function closeBox()
{
    document.getElementById('testInfo').innerHTML += 'closeBox<br/>';
}
</script>
</body>
</html>

在上面的例子中,你发现点击关闭按钮的时候,标题栏的mousedown事件也触发了,显然这是在你意料之中的,因为你知道这正是JavaScript事件冒泡在起作用。其实你真正要的效果是点关闭按钮的时候,不要执行标题H5注册的mousedown事件,于是你想到了阻止事件冒泡,接着代码修改成下面这样:

<div id="box">
<h5 onmousedown="startDrag();"><a onclick="closeBox(event);" href="javascript:void(0);">×</a></h5>
<div id="testInfo"></div>
</div>
<script type="text/javascript">
function startDrag()
{
    document.getElementById('testInfo').innerHTML += 'startDrag<br/>';
}
function closeBox(e)
{
    document.getElementById('testInfo').innerHTML += 'closeBox<br/>';
    stopBubble(e);
}

//阻止事件冒泡函数
function stopBubble(e)
{
    if (e && e.stopPropagation)
        e.stopPropagation();
    else
        window.event.cancelBubble=true;
}
</script

结果你发现单击关闭按钮的时候,标题H5注册的mousedown事件还是执行了,这是怎么回事呢?其实细心的你可能发现,H5标题和A链接注册的事件不是一样的,在上面的代码中,我们在A链接注册的click事件中调用阻止事件方法,这只是意味着其父元素注册的“同类事件”不会执行,意思是说如果H5标题也注册了click事件,这个click事件不会执行,而这里的mousedown就继续执行了。这里的mousedown执行不是因为你点中标题栏而发生的,是由于你在单击click的时候伴随产生mousedown事件,然后又由于JavaScript事件冒泡机制的存在,事件向父级广播并被H5标题mousedown注册方法捕获。关于对这点的理解,可以参考我另外一篇博客《当onmousedown、onmouseup、onclick同时应用于同一个标签节点Element》。现在,通过分析,你应该知道怎么做了,小改上面的代码,只要把A链接的click事件改成与H5标题一样的mousedown事件,你想要的效果就实现了。

相关话题:

现在讲讲如何在使用jQuery开发时轻松阻止事件冒泡。jQuery作为一个优秀的脚本框架,对事件的封装及浏览器兼容处理自然也是很出众的。想了解更多也可阅读我的另外一篇博客《利用jQuery的$.event.fix函数统一浏览器event处理》。

使用jQuery要想阻止事件冒泡方法有二:

1、利用jQuery做过兼容处理的event对象,直接使用event.stopPropagation(),举例代码如下:

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3/jquery.min.js"></script>
<div id="box">
<h5 onmousedown="startDrag();"><a onmousedown="closeBox(event);" href="javascript:void(0);">×</a></h5>
<div id="testInfo"></div>
</div>
<script type="text/javascript">
function startDrag()
{
    document.getElementById('testInfo').innerHTML += 'startDrag<br/>';
}
function closeBox(e)
{
    document.getElementById('testInfo').innerHTML += 'closeBox<br/>';
    var event = $.event.fix(e);
    event.stopPropagation();
}
</script>

2、在jQuery绑定的函数中返回false,即return false。注意:不是使用jQuery绑定的方法返回false是没有用的。代码如下:

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3/jquery.min.js"></script>
<div id="box">
<h5 onmousedown="startDrag();"><a href="javascript:void(0);">×</a></h5>
<div id="testInfo"></div>
</div>
<script type="text/javascript">
function startDrag()
{
    document.getElementById('testInfo').innerHTML += 'startDrag<br/>';
}
function closeBox()
{
    document.getElementById('testInfo').innerHTML += 'closeBox<br/>';
    return false;
}

$('#box a').bind('mousedown',closeBox);
</script>

最后还要说明一下,利用第二个方法阻止事件冒泡,同时也阻止了浏览器的默认行为,在jQuery事件处理的源代码的handle方法中(jQuery JavaScript Library v1.3.2非压缩代码2700行)我们可以看到向下面这样的处理,其中event.preventDefault()是用于阻止浏览器默认行为。

handle : function(event)
{
    //other code......
    if (ret === false) 
    {
        event.preventDefault();
        event.stopPropagation();
    }
    //other code......
}

JavaScript事件冒泡应用实例相关推荐

  1. JavaScript事件冒泡简介及应用

    JavaScript事件冒泡简介及应用 一.什么是事件冒泡 在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件 ...

  2. JavaScript事件冒泡和事件委托

    JavaScript事件冒泡和事件委托 付建宇 - 2 条评论 接触JavaScript不久,学的东西也不是特别多.小雨就是习惯把平时学到的东西拿出来分享.一方面加强自己的印象,一方面可以让自己的经验 ...

  3. JavaScript事件冒泡、事件捕获和阻止默认事件

    谈起JavaScript的 事件,事件冒泡.事件捕获.阻止默认事件这三个话题,无论是面试还是在平时的工作中,都很难避免. 冒泡篇 先来看一段实例: js: var $input = document. ...

  4. JavaScript 事件冒泡简介及应用(转)

    http://www.jb51.net/article/21801.htm 一.什么是事件冒泡 在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会 ...

  5. javascript 事件冒泡 和 冒泡事件阻止

    本文摘自网友的文章 http://www.cnblogs.com/wuhen/archive/2010/08/12/1798348.html http://www.cnblogs.com/jams74 ...

  6. JavaScript事件冒泡

    2019独角兽企业重金招聘Python工程师标准>>> 事件的冒泡和捕获 事件的冒泡有什么好处 事件冒泡的优点和缺点 不是所有的事件都能冒泡 阻止事件冒泡 阻止jQuery事件冒泡 ...

  7. javascript 事件冒泡处理方式

    在工作中遇到 javascript 冒泡的情况,特此记录一下.我们要实现点击包含此课程vip上面的区域进行关闭窗口也就是div的隐藏,点击 包含此课程vip 以下的区域不进行关闭窗口,实际效果是下面的 ...

  8. 阻止JavaScript事件冒泡到父元素

    前言 略 问题 有代码如下: <div class='preview_image_container'><!--图片--><div onclick='details(th ...

  9. javascript 事件冒泡和事件代理

    事件冒泡 简单的讲,当子元素的事件处理函数被触发(如onclick),该事件会从事件源(当前子元素)逐级向上层元素传递,触发祖先元素的 onclik 事件,一直到最外层 html 根元素. 这可能会带 ...

最新文章

  1. 看完这篇文章之后,终于明白了编译到底怎么回事。
  2. Makefile与Shell的问题
  3. JS 正则表达式(数字、正则)
  4. 【重点突破】—— React实现富文本编辑器
  5. 招商银行王龙:金融科技银行数据架构设计的13条守则(含PPT)
  6. 用css3做一个求婚小动画
  7. MVC系列学习(十一)-客户端的验证
  8. oracle中断进程,中断ORACLE数据库关闭进程导致错误案例
  9. ExceptionError
  10. 稳居TIOBE前三,涨幅No.1,Python做了什么?
  11. C++字符串空格替换题
  12. win7旗舰版和纯净版系统哪个好
  13. 景嘉微变更会计师事务所引发投资者担忧
  14. 纯C语言写计算器界面
  15. 火山中文编程 -- 载入窗口
  16. MATLAB GUI 实现串口通信,制作串口助手(教材级别的宝藏内容!!)
  17. python数据分析报告范文_Python数据分析求解题
  18. 深入了解JS的Number类型
  19. [NOIP2014]珠心算测验 T1
  20. [学习SLAM]深度学习+视觉SLAM 的可行性/方向

热门文章

  1. 【附源码】计算机毕业设计java智能居家养老服务平台设计与实现
  2. IT公司全国排行榜 (2006-6-21更新)
  3. ccleaner中文版下载
  4. 分享几款超级好用的手机APP,你肯定能用到
  5. 曙光服务器如何重新设置u盘启动_曙光服务器常见问题
  6. 前端调用打印机打印条码、二维码(一些坑)
  7. 从阿里高层辞职想到的
  8. 手机NFC通信的安全车钥匙
  9. Picasso实现下载圆形头像以及圆角图片
  10. 维汉智能翻译android版最新版,维汉智能翻译词典最新版下载-维汉智能翻译下载2018下载 v3.0.6免费版_5577安卓网...