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,如需转载请自行联系原作者

相关文章
|
8月前
|
JavaScript 算法
|
8月前
|
JavaScript
事件触发、事件捕获与事件冒泡(js的问题)
事件触发、事件捕获与事件冒泡(js的问题)
47 0
|
3月前
|
JavaScript 前端开发 UED
JS DOM 事件流与事件冒泡
【10月更文挑战第16天】理解 DOM 事件流和事件冒泡是掌握 JavaScript 事件处理的关键。通过合理利用事件冒泡,可以实现更高效、灵活的事件处理机制,提升用户体验和开发效率。在实际开发中,要根据具体情况灵活运用这些概念,以达到最佳的效果。
108 42
|
6月前
|
JavaScript
js 事件流、事件冒泡、事件捕获、阻止事件的传播
js 事件流、事件冒泡、事件捕获、阻止事件的传播
99 1
|
8月前
|
JavaScript
js_操作dom(委托和冒泡事件)
js_操作dom(委托和冒泡事件)
51 0
|
8月前
|
JavaScript
js中的事件冒泡和事件捕捉
js中的事件冒泡和事件捕捉
51 0
|
8月前
|
JavaScript 前端开发
【面试题】对JS中的事件冒泡、事件捕获、事件委托的理解
【面试题】对JS中的事件冒泡、事件捕获、事件委托的理解
|
JavaScript 前端开发
原生JavaScript之dom如何进行事件监听(事件捕获/冒泡)
原生JavaScript之dom如何进行事件监听(事件捕获/冒泡)
169 1
|
JavaScript 容器
js中的事件冒泡与事件捕获
js中的事件冒泡与事件捕获
50 0
|
JavaScript 前端开发
JS的冒泡和如何阻止事件冒泡
JS的冒泡和如何阻止事件冒泡
182 0