在点击div中的p时,如何阻止事件冒泡

发布时间 - 2026-01-10 22:54:00    点击率:

今天整理笔记,发现在学习javaScript的过程中,遇到过一个在当时看来很棘手的问题,现在特地总结一下,也希望能帮助到曾像我一样迷惘的初学者。

我还是以一个案例来说明问题,html代码如下:

 <div onclick="show('a')">
   <p onclick="show('b')"></p>
 </div>

css代码如下:

div{
  width:500px;
  height:500px;
  background:red;
 }
 p{
  width:200px;
  height:200px;
  background:blue;
 }

js代码如下:

 function show(info){
    alert(info);
 }

稍微懂点js的人都知道当我点击p时,基于事件冒泡机制,会触发父元素div的onclick事件,结果是先弹出b、再弹出a。

那么问题来了,如何修改show()这个函数而只弹出b?我第一次的解决方法是(各位大神勿喷):

function show(e,info){
 function cancelBubble(e){
  e = e || window.event;
  if (e.stopPropagation) {  
     e.stopPropagation(); 
  }else {   
     e.cancelBubble = true; 
  } 
 }
 alert(info);
}

结果老是报错。我就开始各种百度,最终解决方法如下:

function show(info){
   alert(info);
   cancelBubble();
}
function cancelBubble(e) { 
   var evt = e ? e : window.event; 
    if (evt.stopPropagation) {  //W3C 
     evt.stopPropagation(); 
    }else {  //IE  
     evt.cancelBubble = true; 
    } 
}

至于为什么这样?我分析的是这样做有两个好处:1.阻止了事件冒泡,达到只弹出b目的; 2.将阻止事件冒泡的代码封装成了一个函数,可以多次调用。

好了,问题圆满解决。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# 阻止点击事件冒泡  # div阻止冒泡  # 阻止冒泡事件  # 利用JQuery阻止事件冒泡  # 兼容各大浏览器的JavaScript阻止事件冒泡代码  # js阻止默认事件与js阻止事件冒泡示例分享 js阻止冒泡事件  # JQuery中阻止事件冒泡几种方式及其区别介绍  # js阻止冒泡及jquery阻止事件冒泡示例介绍  # jQuery阻止事件冒泡具体实现  # 事件冒泡是什么如何用jquery阻止事件冒泡  # jquery 事件冒泡的介绍以及如何阻止事件冒泡  # Jquery阻止事件冒泡 event.stopPropagation  # cancelBubble阻止事件冒泡  # 弹出  # 的是  # 我就  # 来了  # 成了  # 好了  # 我还  # 当我  # 的人都  # 希望能  # 大神  # 这样做  # 报错  # 解决方法  # 遇到过  # 过程中  # 方法如下  # 而只  # 像我一样  # 一个函数 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Win11怎样安装网易有道词典_Win11安装词典教程【步骤】  Google浏览器为什么这么卡 Google浏览器提速优化设置步骤【方法】  百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧  Win11怎么关闭专注助手 Win11关闭免打扰模式设置【操作】  Android利用动画实现背景逐渐变暗  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  如何快速生成凡客建站的专业级图册?  Firefox Developer Edition开发者版本入口  php json中文编码为null的解决办法  如何在阿里云服务器自主搭建网站?  php485函数参数是什么意思_php485各参数详细说明【介绍】  如何用低价快速搭建高质量网站?  JS弹性运动实现方法分析  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  EditPlus中的正则表达式 实战(4)  Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践  奇安信“盘古石”团队突破 iOS 26.1 提权  详解Oracle修改字段类型方法总结  ,交易猫的商品怎么发布到网站上去?  nginx修改上传文件大小限制的方法  新三国志曹操传主线渭水交兵攻略  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  Laravel Admin后台管理框架推荐_Laravel快速开发后台工具  标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  如何破解联通资金短缺导致的基站建设难题?  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  php静态变量怎么调试_php静态变量作用域调试技巧【解答】  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】  Win11怎么设置默认图片查看器_Windows11照片应用关联设置  Android自定义控件实现温度旋转按钮效果  如何用美橙互联一键搭建多站合一网站?  Laravel怎么做缓存_Laravel Cache系统提升应用速度的策略与技巧  Laravel如何实现用户注册和登录?(Auth脚手架指南)  Laravel Docker环境搭建教程_Laravel Sail使用指南  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  中山网站制作网页,中山新生登记系统登记流程?  如何快速使用云服务器搭建个人网站?  Laravel如何创建自定义Artisan命令?(代码示例)  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  手机网站制作与建设方案,手机网站如何建设?  JavaScript如何实现错误处理_try...catch如何捕获异常?  七夕网站制作视频,七夕大促活动怎么报名?