欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jQuery阻止同類型事件小結(jié)

 更新時(shí)間:2013年04月19日 14:54:37   作者:  
事件追加:點(diǎn)擊green元素會(huì)依次執(zhí)行g(shù)reen click1、green click2兩個(gè)事件(同一元素的同類型事件),感興趣的朋友可以參考下哈
復(fù)制代碼 代碼如下:

<!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元素的父元素。
復(fù)制代碼 代碼如下:

$(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元素添加了三個(gè)click事件。
當(dāng)點(diǎn)擊子元素green元素時(shí),會(huì)依次執(zhí)行g(shù)reen click1、green click2、red click事件。
事件追加:點(diǎn)擊green元素會(huì)依次執(zhí)行g(shù)reen click1、green click2兩個(gè)事件(同一元素的同類型事件)。
事件冒泡:點(diǎn)擊green元素會(huì)觸發(fā)父元素的red click事件(父級(jí)元素的同類型事件)。
1、 在子元素事件函數(shù)中阻止事件冒泡
方法1:event.stopPropagation()
復(fù)制代碼 代碼如下:

$(function(){
$("#green").click(function(event){
event.stopPropagation();
alert("green click");
});
$("#red").click(function(event){
alert("red click");
});
});

方法2:return false
復(fù)制代碼 代碼如下:

$(function(){
$("#green").click(function(event){
alert("green click");
return false;
});
$("#red").click(function(event){
alert("red click");
});
});

通過上面的兩種方法,點(diǎn)擊子元素green區(qū)域后,red click事件被阻止不再執(zhí)行。但不會(huì)影響red元素其他區(qū)域的點(diǎn)擊。
二者區(qū)別:
return false相當(dāng)于event.preventDefault()+event.stopPropagation()。
2、 在父元素事件函數(shù)中阻止事件冒泡
復(fù)制代碼 代碼如下:

$(function(){
$("#green").click(function(event){
alert("green click");
});
$("#red").click(function(event){
if(event.target == this)
{
alert("red click");
}
});
});

通過if(event.target== this)判斷點(diǎn)擊的目標(biāo)元素是不是red元素本身,如果不是red本身而是它的子元素green元素,則不會(huì)執(zhí)行if內(nèi)的代碼。
3、 阻止事件追加
以上的方法只能阻止事件冒泡(也就是父級(jí)元素的同類型事件),但不能阻止事件追加(同一元素的同類型事件)。
復(fù)制代碼 代碼如下:

$(function(){
$("#green").click(function(event){
event.stopImmediatePropagation();
alert("green click");
});
$("#green").click(function(){
alert("green click2");
});
});

event.stopImmediatePropagation()不但可以阻止green click2事件,同時(shí)也阻止事件冒泡。

相關(guān)文章

最新評(píng)論