深入理解jQuery中的事件冒泡

avatar 2017年02月23日17:33:26 3 2751 views
博主分享免费Java教学视频,B站账号:Java刘哥 ,长期提供技术问题解决、项目定制:本站商品点此
1.什么是冒泡

eg:
  1. <!DOCTYPE html>
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  5.   <title>事件冒泡</title>
  6.   <script src="../../js/jQuery1.11.1.js"></script>
  7.   <script type="text/javascript">
  8.     $(function () {
  9.       //为span元素绑定click事件
  10.       $('span').bind('click', function () {
  11.         var txt = $('#msg').html() + '<p>内层span元素被点击</p>';
  12.         $('#msg').html(txt);
  13.       });
  14.       //为span元素绑定click事件
  15.       $('#content').bind('click', function () {
  16.         var txt = $('#msg').html() + '<p>外层div元素被点击</p>';
  17.         $('#msg').html(txt);
  18.       });
  19.       //为span元素绑定click事件
  20.       $('body').bind('click', function () {
  21.         var txt = $('#msg').html() + '<p>body元素被点击</p>';
  22.         $('#msg').html(txt);
  23.       });
  24.     });
  25.   </script>
  26. </head>
  27. <body>
  28.   <div id="content">
  29.     外层div元素
  30.     <span>内层span元素</span>
  31.   </div>
  32.   <div id="msg"></div>
  33. </body>
  34. </html>



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

即:

内层span元素被点击

外层div元素被点击

body元素被点击

这就是事件冒泡引起的。





2.事件冒泡引发的问题

01.事件对象

在程序中使用事件对象,只需要为函数添加一个参数,jQuery代码如下:
  1. $('element').bind('click',function(event){ //event:事件对象
  2. });



02.停止事件冒泡

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

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



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

即:

内层span元素被点击

这样就解决了冒泡问题

03.阻止默认行为

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

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

eg:以输入提交为例
  1. <!DOCTYPE html>
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
  5.   <title></title>
  6.   <script src="../../js/jQuery1.11.1.js"></script>
  7.   <script type="text/javascript">
  8.     $(function () {
  9.       $('#sub').bind('click', function (event) {
  10.         var username = $('#username').val(); //获取元素的值
  11.         if (username == "") {  //判断是否为空
  12.           alert('文本框的值不能为空'); //提示信息
  13.           event.preventDefault(); //阻止默认行为(表单提交)
  14.         }
  15.       });
  16.     });
  17.   </script>
  18. </head>
  19. <body>
  20.   <form action="/">
  21.     用户名:<input type="text" id="username" />
  22.     <input type="submit" value="提交" id="sub" />
  23.   </form>
  24. </body>
  25. </html>

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

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

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

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

改写为:return false;

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

改写为:return false;

04.事件捕获



05.事件对象的属性



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

  • 微信
  • 交流学习,资料分享
  • weinxin
  • 个人淘宝
  • 店铺名:言曌博客咨询部

  • (部分商品未及时上架淘宝)
avatar

发表评论

avatar 登录者:匿名
匿名评论,评论回复后会有邮件通知

  

已通过评论:1   待审核评论数:0
  1. avatar 本质教育

    比博客的名字我真的读不出来;

    • avatar 言曌

      哈哈哈,博客今天可能会关闭。正在备案