- <!DOCTYPE HTML>
- <html>
- <head>
- <title>test</title>
- <script src="http://code.jquery.com/jquery-1.9.1.min.js"></script>
- </head>
- <body>
- <div style="height:300px;background-color:red;" id="red">
- <div style="height:200px;background-color:green;" id="green">
- </div>
- </div>
- </body>
- </html>
在上面的HTML中,red元素是green元素的父元素。
- $(function(){
- $("#green").click(function(event){
- alert("green click1");
- });
- $("#green").click(function(event){
- alert("green click2");
- });
- $("#red").click(function(event){
- alert("red click");
- });
- });
上面的js代码给red元素和green元素添加了三个click事件。
当点击子元素green元素时,会依次执行green click1、green click2、red click事件。
事件追加:点击green元素会依次执行green click1、green click2两个事件(同一元素的同类型事件)。
事件冒泡:点击green元素会触发父元素的red click事件(父级元素的同类型事件)。
1、 在子元素事件函数中阻止事件冒泡
方法1:event.stopPropagation()
- $(function(){
- $("#green").click(function(event){
- event.stopPropagation();
- alert("green click");
- });
- $("#red").click(function(event){
- alert("red click");
- });
- });
方法2:return false
- $(function(){
- $("#green").click(function(event){
- alert("green click");
- return false;
- });
- $("#red").click(function(event){
- alert("red click");
- });
- });
通过上面的两种方法,点击子元素green区域后,red click事件被阻止不再执行。但不会影响red元素其他区域的点击。
二者区别:
return false相当于event.preventDefault()+event.stopPropagation()。
2、 在父元素事件函数中阻止事件冒泡
- $(function(){
- $("#green").click(function(event){
- alert("green click");
- });
- $("#red").click(function(event){
- if(event.target == this)
- {
- alert("red click");
- }
- });
- });
通过if(event.target== this)判断点击的目标元素是不是red元素本身,如果不是red本身而是它的子元素green元素,则不会执行if内的代码。
3、 阻止事件追加
以上的方法只能阻止事件冒泡(也就是父级元素的同类型事件),但不能阻止事件追加(同一元素的同类型事件)。
- $(function(){
- $("#green").click(function(event){
- event.stopImmediatePropagation();
- alert("green click");
- });
- $("#green").click(function(){
- alert("green click2");
- });
- });
event.stopImmediatePropagation()不但可以阻止green click2事件,同时也阻止事件冒泡。
本文介绍了如何在HTML与JavaScript中阻止事件冒泡和事件追加,包括使用`event.stopPropagation()`、`return false`、`event.stopImmediatePropagation()`等方法,并解释了它们的区别。

2712

被折叠的 条评论
为什么被折叠?



