博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jquery,禁止冒泡和默认行为
阅读量:6974 次
发布时间:2019-06-27

本文共 964 字,大约阅读时间需要 3 分钟。

如果在页面中重叠了多个元素,并且重叠的这些元素都绑定了同一个事件,那么就会出

现冒泡问题。
//HTML 页面
<div style="width:200px;height:200px;background:red;">
<input type="button" value="按钮" />
</div>
//三个不同元素触发事件
$('input').click(function () {
alert('按钮被触发了!');
});
$('div').click(function () {
alert('div 层被触发了!');
});
$(document).click(function () {
alert('文档页面被触发了!');
});
注意:当我们点击文档的时候,只触发文档事件;当我们点击 div 层时,触发了 div 和
文档两个;当我们点击按钮时,触发了按钮、div 和文档。触发的顺序是从小范围到大范围。
这就是所谓的冒泡现象,一层一层往上。
jQuery 提供了一个事件对象的方法:event.stopPropagation();这个方法设置到需要触发
的事件上时,所有上层的冒泡行为都将被取消。
$('input').click(function (e) {
alert('按钮被触发了!');
e.stopPropagation();
});
网页中的元素,在操作的时候会有自己的默认行为。比如:右击文本框输入区域,会弹
出系统菜单、点击超链接会跳转到指定页面、点击提交按钮会提交数据。
$('a').click(function (e) {
e.preventDefault();
});
//禁止提交表单跳转
$('form').submit(function (e) {
e.preventDefault();
});
注意:如果想让上面的超链接同时阻止默认行为且禁止冒泡行为,可以把两个方法同时
写上:event.stopPropagation()和 event.preventDefault()。这两个方法如果需要同时启用的时候,
还有一种简写方案代替,就是直接 return false。
$('a').click(function (e) {
return false;
});

转载地址:http://ylosl.baihongyu.com/

你可能感兴趣的文章
遍历Map集合的几种方法
查看>>
pg数据库忘记密码
查看>>
209. Minimum Size Subarray Sum
查看>>
面面观 | CentOS install etcd 测试
查看>>
C#之选择排序
查看>>
MGR架构~MGR+proxysql(1)
查看>>
Leetcode | Next Permutation
查看>>
Delphi动态事件深入分析
查看>>
IntelliJ IDEA 14 注册码
查看>>
threadid=1: thread exiting with uncaught exception (group=0x417cce00)问题
查看>>
[CF566A]Matching Names
查看>>
Clairaut 定理 证明
查看>>
SQL获取当前日期的年、月、日、时、分、秒数据
查看>>
页面优化
查看>>
视频直播技术详解:直播的推流调度
查看>>
js的介绍
查看>>
JavaScript数据类型
查看>>
Emacs 番茄钟 pomidor
查看>>
oracle 分组查询 子查询 统计查询 FROM加子查询临时表 查询高于平均工资 示例代码...
查看>>
.Net程序随系统开机启动(仿Foxmail托盘效果控制)
查看>>