图文课程 职群旗下

  1. 首页
  2. 所有分类
  3. 前端
  4. jQuery中的事件冒泡

jQuery中的事件冒泡

1.什么是冒泡

 eg:

<!DOCTYPE html>
<html xmlns="http:
//www.w3.org/1999/xhtml
">
<head>
<meta http-equiv="Content-Type" content="text/html;
charset=utf-8
"/>
<title>事件冒泡</title>
<script src="../../js/jQuery1.11.1.js"></script>
<script type="text/javascript">$(function () {
//
为span元素绑定click事件$('span').bind('click', function () {var txt = $('#msg').html() + '<p>内层span元素被点击</p>';
$(
'#msg').html(txt);
});

//
为span元素绑定click事件$('#content').bind('click', function () {var txt = $('#msg').html() + '<p>外层div元素被点击</p>';
$(
'#msg').html(txt);
});

//
为span元素绑定click事件$('body').bind('click', function () {var txt = $('#msg').html() + '<p>body元素被点击</p>';
$(
'#msg').html(txt);
});
});
</script>
</head>
<body>
<div id="content">外层div元素<span>内层span元素</span>
</div>
<div id="msg"></div>
</body>
</html>

当你单击‘内层span元素’时,即触发<span>元素的click事件时,会输出3条记录

即:

内层span元素被点击

外层div元素被点击

body元素被点击

 

这就是事件冒泡引起的。

 

2.事件冒泡引发的问题

   01.事件对象

   在程序中使用事件对象,只需要为函数添加一个参数,jQuery代码如下:

$('element').bind('click',function(event){
//
event:事件对象});

  02.停止事件冒泡

  在jQuery中提供了stopPropagation()方法来停止事件冒泡

以span元素绑定click事件为例:

 
//
为span元素绑定click事件$('span').bind('click', function (event) {
//
event:事件对象var txt = $('#msg').html() + '<p>内层span元素被点击</p>';
$(
'#msg').html(txt);
event.stopPropagation();

//
停止事件冒泡});

当你单击‘内层span元素’时,即触发<span>元素的click事件时,这时只会输出1条记录

即:

内层span元素被点击

 

这样就解决了冒泡问题

 03.阻止默认行为

  网页中的元素有自己默认的行为,例如,单击超链接后会跳转,单击‘提交’表单会提交,有时需要阻止元素的默认行为

在jQuery中,提供了preventDefault()方法来阻止元素的默认行为。

eg:以输入提交为例

<!DOCTYPE html>
<html xmlns="http:
//www.w3.org/1999/xhtml
">
<head>
<meta http-equiv="Content-Type" content="text/html;
charset=utf-8
"/>
<title></title>
<script src="../../js/jQuery1.11.1.js"></script>
<script type="text/javascript">$(function () {$('#sub').bind('click', function (event) {var username = $('#username').val();

//
获取元素的值if (username == "") {
//
判断是否为空alert('文本框的值不能为空');

//
提示信息event.preventDefault();

//
阻止默认行为(表单提交) }

});
});
</script>
</head>
<body>
<form action="/">用户名:<input type="text" id="username" />
<input type="submit" value="提交" id="sub" />
</form>
</body>
</html>

假如你不输入内容,这样就可以阻止默认行为(表单提交)

总结:如果想同时对事件停止冒泡和默认行为,可以在事件处理函数中返回false。这是对在事件对象上同时调用stopPropagation()方法和preventDefault()方法的一种简写方式。

 在上面表单的例子中,可以把

event.preventDefault();

//阻止默认行为(表单提交)
改写为:
return false;

也可以把事件冒泡中的

event.stopPropagation();

//停止事件冒泡
改写为:
return false;

04.事件捕获

05.事件对象的属性

 

事件对象的属性 详情请参考:http://www.w3school.com.cn/jsref/dom_obj_event.asp

 

猜你喜欢
Web前端的35个jQuery小技巧 jQuery分析(3) - jQuery.fn.init
jQuery中的动画与特效 jQuery中事件与动画的总结
CSS弹性盒模型flex在布局中的应用 解决zabbix图中出现中文乱码问题 图中的中文会变成方块
Web前端新人笔记之jquery选择符 不写完不让回家的JQuery的事件与动画
jquery如何判断checkbox(复选框)是否被选中 【Simple Java】Java中的内部接口