手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >jQuery阻止同类型事件小结
jQuery阻止同类型事件小结
摘要:复制代码代码如下:test在上面的HTML中,red元素是green元素的父元素。复制代码代码如下:$(function(){$("#gre...

复制代码 代码如下:

<!DOCTYPE HTML>

<html>

<head>

<title>test</title>

<script src="http://code.jquery.com/jquery-1.9.1.min.js"></script>

</head>

<body>

<div id="red">

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

【jQuery阻止同类型事件小结】相关文章:

jQuery实现div随意拖动的实例代码(通用代码)

jQuery插件expander实现图片翻转特效

jquery插件validation实现验证身份证号等

jquery使用经验小结

JS或jQuery获取ASP.NET服务器控件ID的方法

创建表格,并添加事件

jQuery实现延迟跳转的方法

Java数据类型以及变量的定义

js实现异步循环实现代码

jquery 构造函数在表单提交过程中修改数据

精品推荐
分类导航