深入理解jQuery中的事件冒泡


Posted in Javascript onMay 24, 2016

1.什么是冒泡

eg:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  <title>事件冒泡</title>
  <script src="../../js/jQuery1.11.1.js"></script>
  <script type="text/javascript">
    $(function () {
      //为span元素绑定click事件
      $('span').bind('click', function () {
        var txt = $('#msg').html() + '<p>内层span元素被点击</p>';
        $('#msg').html(txt);
        
      });
      //为span元素绑定click事件
      $('#content').bind('click', function () {
        var txt = $('#msg').html() + '<p>外层div元素被点击</p>';
        $('#msg').html(txt);
      });
      //为span元素绑定click事件
      $('body').bind('click', function () {
        var txt = $('#msg').html() + '<p>body元素被点击</p>';
        $('#msg').html(txt);
      });
    });
    
  </script>
</head>
<body>
  <div id="content">
    外层div元素
    <span>内层span元素</span>
  </div>
  <div id="msg"></div>
</body>
</html>

当你单击‘内层span元素'时,即触发<span>元素的click事件时,会输出3条记录

即:

内层span元素被点击

外层div元素被点击

body元素被点击

这就是事件冒泡引起的。

深入理解jQuery中的事件冒泡

 

2.事件冒泡引发的问题

01.事件对象

在程序中使用事件对象,只需要为函数添加一个参数,jQuery代码如下:

$('element').bind('click',function(event){ //event:事件对象

});

02.停止事件冒泡

在jQuery中提供了stopPropagation()方法来停止事件冒泡

以span元素绑定click事件为例:

//为span元素绑定click事件
      $('span').bind('click', function (event) { //event:事件对象
        var txt = $('#msg').html() + '<p>内层span元素被点击</p>';
        $('#msg').html(txt);
        event.stopPropagation(); //停止事件冒泡
      });

当你单击‘内层span元素'时,即触发<span>元素的click事件时,这时只会输出1条记录

即:

内层span元素被点击

这样就解决了冒泡问题

03.阻止默认行为

网页中的元素有自己默认的行为,例如,单击超链接后会跳转,单击‘提交'表单会提交,有时需要阻止元素的默认行为

在jQuery中,提供了preventDefault()方法来阻止元素的默认行为。

eg:以输入提交为例

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  <title></title>
  <script src="../../js/jQuery1.11.1.js"></script>
  <script type="text/javascript">
    $(function () {
      $('#sub').bind('click', function (event) {
        var username = $('#username').val(); //获取元素的值
        if (username == "") {  //判断是否为空
          alert('文本框的值不能为空'); //提示信息
          event.preventDefault(); //阻止默认行为(表单提交)
        }
      });
    });
  </script>
</head>
<body>
  <form action="/">
    用户名:<input type="text" id="username" />
    <input type="submit" value="提交" id="sub" />
  </form>  
</body>
</html>

假如你不输入内容,这样就可以阻止默认行为(表单提交)

总结:如果想同时对事件停止冒泡和默认行为,可以在事件处理函数中返回false。这是对在事件对象上同时调用stopPropagation()方法和preventDefault()方法的一种简写方式。

在上面表单的例子中,可以把

event.preventDefault();  //阻止默认行为(表单提交)

改写为:return false;

也可以把事件冒泡中的event.stopPropagation(); //停止事件冒泡

改写为:return false;

04.事件捕获

深入理解jQuery中的事件冒泡

05.事件对象的属性

 深入理解jQuery中的事件冒泡

事件对象的属性 详情请参考:http://www.w3school.com.cn/jsref/dom_obj_event.asp

以上这篇深入理解jQuery中的事件冒泡就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript里使用Dom操作Xml
Jan 22 Javascript
jQuery结合PHP+MySQL实现二级联动下拉列表[实例]
Nov 15 Javascript
jquery插件制作教程 txtHover
Aug 17 Javascript
JavaScript中判断页面关闭、页面刷新的实现代码
Aug 27 Javascript
javascript算法题:求任意一个1-9位不重复的N位数在该组合中的大小排列序号
Apr 01 Javascript
js贪吃蛇游戏实现思路和源码
Apr 14 Javascript
原生js实现水平方向无缝滚动
Jan 10 Javascript
原生js中ajax访问的实例详解
Sep 19 Javascript
node.js调用C++函数的方法示例
Sep 21 Javascript
vue使用video.js进行视频播放功能
Jul 18 Javascript
javascript中call,apply,callee,caller用法实例分析
Jul 24 Javascript
node.js 如何监视文件变化
Sep 01 Javascript
jQuery 弹出层插件(推荐)
May 24 #Javascript
基于jQuery实现仿QQ空间送礼物功能代码
May 24 #Javascript
深入理解JavaScript中为什么string可以拥有方法
May 24 #Javascript
jQuery height()、innerHeight()、outerHeight()函数的区别详解
May 23 #Javascript
JavaScript程序中的流程控制语句用法总结
May 23 #Javascript
Node.js服务器环境下使用Mock.js拦截AJAX请求的教程
May 23 #Javascript
谈一谈bootstrap响应式布局
May 23 #Javascript
You might like
人尽可用的Windows技巧小贴士之下篇
2007/03/22 PHP
Windows IIS PHP 5.2 安装与配置方法
2009/06/08 PHP
PHP安全配置详细说明
2011/09/26 PHP
ThinkPHP5框架实现简单的批量查询功能示例
2018/06/07 PHP
基于jQuery的输入框无值自动显示指定数据的实现代码
2011/01/24 Javascript
面向对象Javascript核心支持代码分享
2012/05/23 Javascript
javascript算法题 求任意一个1-9位不重复的N位数在该组合中的大小排列序号
2012/07/21 Javascript
基于jquery创建的一个图片、视频缓冲的效果样式插件
2012/08/28 Javascript
密码强度检测效果实现原理与代码
2013/01/04 Javascript
javascript 树形导航菜单实例代码
2013/08/13 Javascript
jquery ajax请求方式与提示用户正在处理请稍等
2014/09/01 Javascript
js实现有时间限制消失的图片方法
2015/02/27 Javascript
js实现简洁的TAB滑动门效果代码
2015/09/06 Javascript
详解基于Bootstrap扁平化的后台框架Ace
2015/11/27 Javascript
分享javascript计算时间差的示例代码
2020/03/19 Javascript
JQuery动态添加Select的Option元素实现方法
2016/08/29 Javascript
jQuery插件echarts实现的多折线图效果示例【附demo源码下载】
2017/03/04 Javascript
Nodejs读取文件时相对路径的正确写法(使用fs模块)
2017/04/27 NodeJs
微信小程序实现弹出层效果
2020/05/26 Javascript
vue通过接口直接下载java生成好的Excel表格案例
2020/10/26 Javascript
python类和继承用法实例
2015/07/07 Python
Python语法快速入门指南
2015/10/12 Python
解决Pycharm下面出现No R interpreter defined的问题
2018/10/29 Python
10招!看骨灰级Pythoner玩转Python的方法
2019/04/15 Python
利用Python绘制Jazz网络图的例子
2019/11/21 Python
win10从零安装配置pytorch全过程图文详解
2020/05/08 Python
Pandas缺失值2种处理方式代码实例
2020/06/13 Python
法国综合购物网站:RueDuCommerce
2016/09/12 全球购物
世界排名第一的万圣节服装店:Spirit Halloween
2018/10/16 全球购物
阿拉伯书店:Jamalon
2019/07/24 全球购物
DC Shoes澳大利亚官方网上商店:购买DC鞋子
2019/10/25 全球购物
Elizabeth Gage官网:英国最好的珠宝设计之一
2020/09/26 全球购物
ktv周年庆活动方案
2014/08/18 职场文书
重阳节活动主持词
2015/07/04 职场文书
幼儿园师德师风心得体会
2016/01/12 职场文书
教你解决往mysql数据库中存入汉字报错的方法
2021/05/06 MySQL