JS冒泡事件 与 事件捕获

简介:

JS冒泡事件 与 事件捕获

案例

<!DOCTYPE html>
<html>
<head>
    <title>冒泡事件</title>
    <script type="text/javascript">
    
        window.onload = function(){
            window.onclick = function(){
                alert("Window"); // 顶级
            };
            
            document.onclick = function(){
                alert("Document"); // 次顶级
            };
            
            document.documentElement.onclick = function(){
                alert("Html"); // 次次顶级
            };
            
            document.body.onclick = function(){
                alert("Body"); // 次次次顶级
            };
            document.getElementById("myDiv").onclick = function(){
                alert("Div"); // 最先执行,并且会传递到上一层。点击两次,则按顺序执行两次。如果上级也有点击事件的话
            };
        }
    

    </script>
</head>
<body>
    <div id="myDiv">点我</div>
</body>
</html>

小结

1.点击myDiv。依次是Div-Body-Html-Document-Window

2.点击其他空白地方。依次是Html-Document-Window

3.连续点击两次,会按顺序执行两次

4.冒泡的前提是,父级也定义了相应的事件

再看一个更复杂的例子

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>事件捕捉</title>
    <script type="text/javascript">
    
        window.onload = function(){
            window.addEventListener("click", function(){
                alert("Window - true");
            }, true); // true - 事件句柄在捕获阶段执行 ,false- false- 默认。事件句柄在冒泡阶段执行
            
            document.addEventListener("click", function(){
                alert("Document - true");
            }, true);
            
            document.documentElement.addEventListener("click", function(){
                alert("Html - true");
            }, true);
            
            document.body.addEventListener("click", function(){
                alert("Body - true");
            }, true);
            document.getElementById("myDiv").addEventListener("click", function(){
                alert("Div - true");
            }, true);

            window.addEventListener("click", function(){
                alert("Window - false");
            }, false); // true - 事件句柄在捕获阶段执行 ,false- false- 默认。事件句柄在冒泡阶段执行

            document.addEventListener("click", function(){
                alert("Document  - false");
            }, false);

            document.documentElement.addEventListener("click", function(){
                alert("Html  - false");
            }, false);

            document.body.addEventListener("click", function(){
                alert("Body  - false");
            }, false);
            document.getElementById("myDiv").addEventListener("click", function(){
                alert("Div  - false");
            }, false);

            window.onclick = function(){
                alert("Window - click"); // 顶级
            };

            document.onclick = function(){
                alert("Document - click"); // 次顶级
            };

            document.documentElement.onclick = function(){
                alert("Html - click"); // 次次顶级
            };

            document.body.onclick = function(){
                alert("Body - click"); // 次次次顶级
            };
            document.getElementById("myDiv").onclick = function(){
                alert("Div - click"); // 最先执行,并且会传递到上一层。点击两次,则按顺序执行两次。如果上级也有点击事件的话
            };
        }
    

    </script>
</head>
<body>
    <div id="myDiv">点我</div>
    
</body>
</html>

小结

1.点击的执行结果是

Window - true

Document - true

Html - true

Body - true

Div - true


Div - false

Div - click


Body - false

Body - click


Html - false

Html - click


Document - false

Document - click


Window - false

Window - click

2.顺序与js代码顺序无关

3.就算没有定义点击事件,一样可以捕获点击事件,只要点击到,就能捕获到

再次改造,阻止冒泡

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>事件捕捉</title>
    <script type="text/javascript">
    
        window.onload = function(){
            document.addEventListener("click", function(){
                alert("Document - true");
            }, true);

            window.addEventListener("click", function(){
                alert("Window - true");
            }, true); // true - 事件句柄在捕获阶段执行 ,false- false- 默认。事件句柄在冒泡阶段执行


            document.documentElement.addEventListener("click", function(){
                alert("Html - true");
            }, true);
            
            document.body.addEventListener("click", function(){
                alert("Body - true");
            }, true);
            document.getElementById("myDiv").addEventListener("click", function(){
                alert("Div - true");
            }, true);

            window.addEventListener("click", function(){
                alert("Window - false");
            }, false); // true - 事件句柄在捕获阶段执行 ,false- false- 默认。事件句柄在冒泡阶段执行

            document.addEventListener("click", function(){
                alert("Document  - false");
            }, false);

            document.documentElement.addEventListener("click", function(){
                alert("Html  - false");
            }, false);

            document.body.addEventListener("click", function(){
                alert("Body  - false");
            }, false);
            document.getElementById("myDiv").addEventListener("click", function(){
                alert("Div  - false");
            }, false);

            window.onclick = function(){
                alert("Window - click"); // 顶级
            };

            document.onclick = function(){
                alert("Document - click"); // 次顶级
            };

            document.documentElement.onclick = function(){
                alert("Html - click"); // 次次顶级
            };

            document.body.onclick = function(){
                alert("Body - click"); // 次次次顶级
            };
            document.getElementById("myDiv").onclick = function(){
                alert("Div - click"); // 最先执行,并且会传递到上一层。点击两次,则按顺序执行两次。如果上级也有点击事件的话
                event.stopPropagation(); // 阻止冒泡
            };
        }
    

    </script>
</head>
<body>
    <div id="myDiv">点我</div>
    
</body>
</html>

小结

Window - true

Document - true

Html - true

Body - true

Div - true


Div - false

Div - click

终止了,没有后续的内容了


本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/5960221.html,如需转载请自行联系原作者

相关文章
|
1月前
|
JavaScript
js两种移除事件的方法
js两种移除事件的方法
33 2
|
30天前
|
存储 JavaScript 前端开发
js事件队列
【10月更文挑战第15天】
44 6
|
1月前
|
JavaScript API
深入解析JS中的visibilitychange事件:监听浏览器标签间切换的利器
深入解析JS中的visibilitychange事件:监听浏览器标签间切换的利器
96 0
|
1月前
|
JavaScript
js两种移除事件的方法
js两种移除事件的方法
51 0
|
1月前
|
JavaScript
js两种移除事件的方法
js两种移除事件的方法
|
1月前
|
JavaScript 前端开发 Android开发
JavaScript触摸touch事件
JavaScript触摸touch事件
|
1月前
|
JavaScript 前端开发 UED
JavaScript 计时事件
JavaScript 计时事件
17 0
|
Web App开发 JavaScript 前端开发
|
4月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
96 2
|
4月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的小区物流配送系统附带文章源码部署视频讲解等
123 4