源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

深入理解jQuery中的事件冒泡

  • 时间:2022-03-23 23:36 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:深入理解jQuery中的事件冒泡
[b]1.什么是冒泡[/b] 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元素被点击 这就是事件冒泡引起的。 [img]http://files.jb51.net/file_images/article/201605/201605240941222.png[/img]   [b]2.事件冒泡引发的问题 [/b] 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>
假如你不输入内容,这样就可以阻止默认行为(表单提交) [b]总结:[/b]如果想同时对事件停止冒泡和默认行为,可以在事件处理函数中返回false。这是对在事件对象上同时调用stopPropagation()方法和preventDefault()方法的一种简写方式。 在上面表单的例子中,可以把 event.preventDefault();  //阻止默认行为(表单提交) 改写为:return false; 也可以把事件冒泡中的event.stopPropagation(); //停止事件冒泡 改写为:return false; 04.事件捕获 [img]http://files.jb51.net/file_images/article/201605/201605240941223.jpg[/img] 05.事件对象的属性  [img]http://files.jb51.net/file_images/article/201605/201605240941224.png[/img] 事件对象的属性 详情请参考:http://www.w3school.com.cn/jsref/dom_obj_event.asp 以上这篇深入理解jQuery中的事件冒泡就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部