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元素
    </div>
    <div id="msg"></div>
</body>
</html>

当您单击‘内层span成分’时,即触发<span>成分的click事件时,会输出3条记下

即:

内层span成分被点击

外层div成分被点击

body成分被点击

 

那就是事件冒泡引起的。

图片 1

 

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.事件捕获

图片 2

05.事件目标的品质

 图片 3

事件目标的习性
详情请参考:http://www.w3school.com.cn/jsref/dom\_obj\_event.asp

 

相关文章

网站地图xml地图