深入理解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(JS)替换节点实现思路介绍
Apr 17 Javascript
javascript中attribute和property的区别详解
Jun 05 Javascript
node.js中的定时器nextTick()和setImmediate()区别分析
Nov 26 Javascript
javascript清空table表格的方法
May 14 Javascript
详解Matlab中 sort 函数用法
Mar 20 Javascript
用户管理的设计_jquery的ajax实现二级联动效果
Jul 13 jQuery
浅析JavaScript中的平稳退化(graceful degradation)
Jul 24 Javascript
vue编译打包本地查看index文件的方法
Feb 23 Javascript
elementui之el-tebs浏览器卡死的问题和使用报错未注册问题
Jul 06 Javascript
解决layui表格内文本超出隐藏的问题
Sep 12 Javascript
JS如何调用WebAssembly编译出来的.wasm文件
Nov 05 Javascript
javascript之Object.assign()的痛点分析
Mar 03 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
生成静态页面的PHP类
2006/07/15 PHP
destoon设置自定义搜索的方法
2014/06/21 PHP
推荐一本PHP程序猿都应该拜读的书
2014/12/31 PHP
PHP中余数、取余的妙用
2015/06/29 PHP
YII视图整合kindeditor扩展的方法
2016/07/13 PHP
php打开本地exe程序,js打开本地exe应用程序,并传递相关参数方法
2018/02/06 PHP
编写可维护面向对象的JavaScript代码[翻译]
2011/02/12 Javascript
JQuery-tableDnD 拖拽的基本使用介绍
2013/07/04 Javascript
jQuery实现图片放大预览实现原理及代码
2013/09/12 Javascript
js操纵dom生成下拉列表框的方法
2014/02/24 Javascript
实现js保留小数点后N位的代码
2014/11/13 Javascript
谈谈javascript中使用连等赋值操作带来的问题
2015/11/26 Javascript
JS实现图片平面旋转的方法
2016/03/01 Javascript
Javascript中apply、call、bind的巧妙使用
2016/08/18 Javascript
jquery.Jcrop结合JAVA后台实现图片裁剪上传实例
2016/11/05 Javascript
Javascript ES6中数据类型Symbol的使用详解
2017/05/02 Javascript
python实现哈希表
2014/02/07 Python
用python代码做configure文件
2014/07/20 Python
Python面向对象编程中的类和对象学习教程
2015/03/30 Python
Django Rest framework之认证的实现代码
2018/12/17 Python
python爬虫简单的添加代理进行访问的实现代码
2019/04/04 Python
如何在Python中实现goto语句的方法
2019/05/18 Python
在Python中等距取出一个数组其中n个数的实现方式
2019/11/27 Python
使用OpenCV获取图像某点的颜色值,并设置某点的颜色
2020/06/02 Python
Python TestSuite生成测试报告过程解析
2020/07/23 Python
django下创建多个app并设置urls方法
2020/08/02 Python
python 检测nginx服务邮件报警的脚本
2020/12/31 Python
matplotlib bar()实现百分比堆积柱状图
2021/02/24 Python
webapp字号大小跟随系统字号大小缩放的示例代码
2018/12/26 HTML / CSS
三年级音乐教学反思
2014/01/28 职场文书
领导班子三严三实心得体会
2014/10/13 职场文书
2014年文明创建工作总结
2014/11/25 职场文书
2015年艾滋病宣传活动总结
2015/03/27 职场文书
海上钢琴师观后感
2015/06/03 职场文书
龙猫观后感
2015/06/09 职场文书
基于JavaScript实现省市联动效果
2021/06/22 Javascript