jQuery阻止同类型事件

<!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事件, 同时 也 阻止事件冒泡


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值