源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

jQuery阻止同类型事件小结

  • 时间:2021-07-17 20:09 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:jQuery阻止同类型事件小结
[u]复制代码[/u] 代码如下:
<!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元素的父元素。
[u]复制代码[/u] 代码如下:
$(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()
[u]复制代码[/u] 代码如下:
$(function(){ $("#green").click(function(event){ event.stopPropagation(); alert("green click"); }); $("#red").click(function(event){ alert("red click"); }); });
方法2:return false
[u]复制代码[/u] 代码如下:
$(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、 在父元素事件函数中阻止事件冒泡
[u]复制代码[/u] 代码如下:
$(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、 阻止事件追加 以上的方法只能阻止事件冒泡(也就是父级元素的同类型事件),但不能阻止事件追加(同一元素的同类型事件)。
[u]复制代码[/u] 代码如下:
$(function(){ $("#green").click(function(event){ event.stopImmediatePropagation(); alert("green click"); }); $("#green").click(function(){ alert("green click2"); }); });
event.stopImmediatePropagation()不但可以阻止green click2事件,同时也阻止事件冒泡。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部