阻止事件冒泡,阻止默认事件,event.stopPropagation()和event.preventDefault(),return fal的区别

简介: 今天来看看前端的冒泡和事件默认事件如何处理 1.event.stopPropagation()方法 这是阻止事件的冒泡方法,不让事件向documen上蔓延,但是默认事件任然会执行,当你掉用这个方法的时候,如果点击一个连接,这个连接仍然会被打开, 2.event.preventDefault()方法 这是阻止默认事件的方法,调用此方法是,连接不会被打开,但是会发生冒泡,冒泡会传递到上

今天来看看前端的冒泡和事件默认事件如何处理

1.event.stopPropagation()方法

这是阻止事件的冒泡方法,不让事件向documen上蔓延,但是默认事件任然会执行,当你掉用这个方法的时候,如果点击一个连接,这个连接仍然会被打开,

2.event.preventDefault()方法

这是阻止默认事件的方法,调用此方法是,连接不会被打开,但是会发生冒泡,冒泡会传递到上一层的父元素;

3.return false  ;

这个方法比较暴力,他会同事阻止事件冒泡也会阻止默认事件;写上此代码,连接不会被打开,事件也不会传递到上一层的父元素;可以理解为return false就等于同时调用了event.stopPropagation()和event.preventDefault()

4.我们来看看几组demo,使用jquery进行DOM操作

这是html代码,div里面套了一个a标签,连接到百度

<div class="box1">
			<a href="http://www.baidu.com" target="_blank"></a>
		</div>
css代码,a标签占父元素的空间的1/4,背景颜色为红色;

.box1{
				height: 200px;
				width: 600px;
				margin: 0 auto;
			}
			.box1 a{
				display: block;
				height: 50%;
				width: 50%;
				background:red;
			}


下面来看js代码,第一种 

//不阻止事件冒泡和默认事件
			
			$(".box1").click(function(){
				console.log("1")//不阻止事件冒泡会打印1,页面跳转;				
			});



第二种

//阻止冒泡
			$(".box1 a").click(function(event){
				event.stopPropagation();//不会打印1,但是页面会跳转;			

			});
			
			$(".box1").click(function(){
				console.log("1")				
});




 
 
 

第三种

$(".box1 a").click(function(event){			
//阻止默认事件
event.preventDefault();//页面不会跳转,但是会打印出1,
});
			
$(".box1").click(function(){
console.log("1");				
});



 
 

第四种

$(".box1").click(function(){
console.log("1")
});			
//阻止冒泡
$(".box1 a").click(function(event){
event.stopPropagation();			
//阻止默认事件
event.preventDefault() //页面不会跳转,也不会打印出1
})



第五种

$(".box1").click(function(){
				console.log("1")				
			});									
$(".box1 a").click(function(event){
				return false;  //页面不会跳转,也不会打印出1,等于同时调用了event.stopPropagation()和event.preventDefault()

});





目录
相关文章
|
前端开发 JavaScript 索引
三大应用场景调研,Webpack 新功能 Module Federation 深入解析
Federated Modules 是一个令人激动的功能,它可能会改变未来几年的前端打包方式,作者深入分析了 Module Federation 的原理及其应用场景,希望能对大家有所启发。
12335 0
三大应用场景调研,Webpack 新功能 Module Federation 深入解析
|
8月前
|
Linux 开发工具 C语言
在CentOS系统中编译安装TinyXml2的方法
以上就是在CentOS系统中编译安装TinyXml2的方法。这个过程可能会有些复杂,但只要你按照上面的步骤一步一步来,你应该能够成功地完成这个任务。如果你在这个过程中遇到任何问题,你可以在网上搜索相关的资料,或者在相关的论坛上寻求帮助。希望这个指南能够帮助你成功地在你的CentOS系统中编译安装TinyXml2。
219 22
|
9月前
|
机器学习/深度学习 设计模式 API
Python 高级编程与实战:构建 RESTful API
本文深入探讨了使用 Python 构建 RESTful API 的方法,涵盖 Flask、Django REST Framework 和 FastAPI 三个主流框架。通过实战项目示例,详细讲解了如何处理 GET、POST 请求,并返回相应数据。学习这些技术将帮助你掌握构建高效、可靠的 Web API。
|
11月前
|
机器学习/深度学习 数据可视化 PyTorch
PyTorch FlexAttention技术实践:基于BlockMask实现因果注意力与变长序列处理
本文介绍了如何使用PyTorch 2.5及以上版本中的FlexAttention和BlockMask功能,实现因果注意力机制与填充输入的处理。通过attention-gym仓库安装相关工具,并详细展示了MultiheadFlexAttention类的实现,包括前向传播函数、因果掩码和填充掩码的生成方法。实验设置部分演示了如何组合这两种掩码并应用于多头注意力模块,最终通过可视化工具验证了实现的正确性。该方法适用于处理变长序列和屏蔽未来信息的任务。
395 17
|
弹性计算 监控 安全
slb使用中安全问题
【11月更文挑战第1天】
296 4
|
存储 运维 Dubbo
SAE急速部署
Serverless应用引擎 2.0的推出,您是否用过?更快速的部署,更低的成本,SAE 2.0 极简体验、极致弹性,助力企业降本增效!
10210 14
SAE急速部署
|
小程序 JavaScript Java
基于微信小程序的外卖小程序的设计与实现(源码+lw+部署文档+讲解等)
基于微信小程序的外卖小程序的设计与实现(源码+lw+部署文档+讲解等)
229 0
|
机器学习/深度学习 传感器 算法
GA-LSTM回归预测 | Matlab遗传算法优化长短时记忆网络回归预测
GA-LSTM回归预测 | Matlab遗传算法优化长短时记忆网络回归预测
|
JSON 移动开发 NoSQL
【ES系列九】——批量同步数据至ES
通过es官网提供的bulk方法进行实现
|
小程序
微信小程序wx.navigateTo跳转参数大小超出限制问题
微信小程序wx.navigateTo跳转参数大小超出限制问题
690 0