您好,欢迎访问一九零五行业门户网

jQuery阻止同类型事件小结_jquery

复制代码 代码如下:
test
在上面的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事件,同时也阻止事件冒泡。
其它类似信息

推荐信息