关于JQuery中的事件冒泡

Posted wwangzhe

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于JQuery中的事件冒泡相关的知识,希望对你有一定的参考价值。

什么是事件冒泡?

事件冒泡就是当父元素和子元素存在同一事件时在子元素的事件处理程序中会自动调用其父级元素的事件处理程序。

demo:

<!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="jquery-1.8.3.min.js"></script>
    <script>
        $(function () {
            $("#div").click(function () {
                $(this).text("我是div");
            });
            $("#img").click(function () {
                $(this).parent().css("border", "1px solid red");
            });
        })
    </script>
</head>
<body>
    <div id="div">
        <img id="img" src="images/gd.jpg" />
    </div>
</body>
</html>

当点击div下的img元素时界面效果如图:

image

通过上面代码我们只是想当鼠标点击图片时让div的边框成红色并没有要删除图片,但他在执行子元素(img)的事件处理程序时自动调用了父级元素(div)这就是事件冒泡。

如何取消事件冒泡?

事件冒泡是可以由程序员手工取消的也就是在子元素的事件处理程序中手动的停止调用父级元素

demo:

<!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="jquery-1.8.3.min.js"></script>
    <script>
        $(function () {
            $("#div").click(function () {
                $(this).text("我是div");
            });
            $("#img").click(function () {
                $(this).parent().css("border", "1px solid red");  event.stopPropagation();
            });
        })
        </script>
</head>
<body>
    <div id="div">
        <img id="img" src="images/gd.jpg" />
    </div>
</body>
</html>

如上所示代码就可以取消事件冒泡

demo:

<!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="jquery-1.8.3.min.js"></script>
    <script>
        $(function () {
            $("#div").click(function () {
                if( event.target == event.currentTarget){
                    $(this).text("我是div");
            }
            });
            $("#img").click(function () {
                if( event.target == event.currentTarget){
                $(this).parent().css("border", "1px solid red");
                }
            });
        })

    </script>
</head>
<body>
    <div id="div">
        <img id="img" src="images/gd.jpg" />
    </div>
</body>
</html>
这种方法也能解决上述问题单其并没有停止事件冒泡他判断其事件的触发元素和当前元素是否是同一个元素如果是则执行处理代码,如果不是则不执行处理代码,但事件还是会逐级向上冒泡直到body元素为止

以上是关于关于JQuery中的事件冒泡的主要内容,如果未能解决你的问题,请参考以下文章

关于什么是事件冒泡和如何取消事件冒泡的讨论!

jQuery中的事件冒泡

jquery的mouseover方法如何阻止事件冒泡

事件冒泡是什么如何用jquery阻止事件冒泡

jquery如何阻止事件冒泡

js中啥是事件气泡,如何阻止事件气泡