一、什么是事件冒泡
在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象传播,从里到外,直至它被处理(父级对象所有同类事件都将被激活),或者它到达了对象层次的最顶层,即document对象(有些浏览器是window)。
打个比方说:你在地方法院要上诉一件案子,如果地方没有处理此类案件的法院,地方相关部门会帮你继续往上级法院上诉,比如从市级到省级,直至到中央法院,最终使你的案件得以处理。
二、事件冒泡有什么作用
(1)事件冒泡允许多个操作被集中处理(把事件处理器添加到一个父级元素上,避免把事件处理器添加到多个子级元素上),它还可以让你在对象层的不同级别捕获事件。
【集中处理例子】
复制代码 代码如下:
<div onclick="eventHandle(event)" id="outSide" style="width:100px; height:100px; background:#000; padding:50px">
<div id="inSide" style="width:100px; height:100px; background:#CCC"></div>
</div>
<script type="text/javascript">
//本例子只在外面盒子定义了处理方法,而这个方法一样可以捕获到子元素点击行为并处理它。假设有成千上万子元素要处理,难道我们要为每个元素加“onclick="eventHandle(event)"”?显然没有这种集中处理的方法来的简单,同时它的性能也是更高的。
function eventHandle(e)
{
var e=e||window.event;
var obj=e.target||e.srcElement;
alert(obj.id+' was click')
}
</script>
(2)让不同的对象同时捕获同一事件,并调用自己的专属处理程序做自己的事情,就像老板一下命令,各自员工做自己岗位上的工作去了。
【同时捕获同一事件例子】
复制代码 代码如下:
<div onclick="outSideWork()" id="outSide" style="width:100px; height:100px; background:#000; padding:50px">
<div onclick="inSideWork()" id="inSide" style="width:100px; height:100px; background:#CCC"></div>
</div>
<script type="text/javascript">
function outSideWork()
{
alert('My name is outSide,I was working...');
}
function inSideWork()
{
alert('My name is inSide,I was working...');
}
//因为下面程序自动激活单击事件,有些浏览器不允许,所以请单击灰色盒子,从这里开始下命令,这样因为冒泡的原因,黑色大盒子也会收到单击事件,并调用了自己的处理程序。如果还有更多盒子嵌套,一样道理。
/*
function bossOrder()
{
document.getElmentById('inSide').click();
}
bossOrder();
*/
</script>
三、需要注意什么
●事件捕获其实有三种方式,事件冒泡只是其中的一种:(1)IE从里到外(inside→outside)的冒泡型事件。(2)Netscape4.0从外到里(outside→inside)的捕获型事件。(3)DOM事件流,先从外到里,再从里到外回到原点(outside→inside→outside)的事件捕获方法(似乎对象将触发两次事件处理,这有什么作用?鄙人不懂!)。
●不是所有的事件都能冒泡。以下事件不冒泡:blur、focus、load、unload。
●事件捕获方式在不同浏览器,甚至同种浏览器的不同版本中是有所区别的。如Netscape4.0采用捕获型事件解决方案,其它多数浏览器则支持冒泡型事件解决方案,另外DOM事件流还支持文本节点事件冒泡。
●事件捕获到达顶层的目标在不同浏览器或不同浏览器版本也是有区别的。在IE6中HTML是接收事件冒泡的,另外大部分浏览器将冒泡延续到window对象,即……body→documen→window。
●阻止冒泡并不能阻止对象默认行为。比如submit按钮被点击后会提交表单数据,这种行为无须我们写程序定制。
四、阻止事件冒泡
通常情况下我们都是一步到位,明确自己的事件触发源,并不希望浏览器自作聪明、漫无目的地去帮我们找合适的事件处理程序,即我们明确最精准目标,这种情况下我们不需要事件冒泡。另外通过对事件冒泡的理解,我们知道程序将做多较多额外的事情,这必然增大程序开销。还有一个重要的问题是:事件冒泡处理可能会激活我们本来不想激活的事件,导致程序错乱,甚至无从下手调试,这常成为对事件冒泡不熟悉程序员的棘手问题。所以必要时,我们要阻止事件冒泡。
【不想激活的事件被激活例子】
复制代码 代码如下:
<div onclick="openWin('http://www.baidu.com')" id="outSide" style="width:100px; height:100px; background:#000; padding:50px">
<div onclick="openWin('http://www.google.com')" id="inSide" style="width:100px; height:100px; background:#CCC"></div>
</div>
<script type="text/javascript">
//本例你实际希望点击灰色盒子打开google首页,而点击黑色盒子打开baidu首页,但结果你点击灰色盒子的时候,却是同时打开了两个网页。其实在实际设计中较少遇到此问题,你可能会想如果我在页面不同DOM深处安置了不同的按钮或链接,深层处的事件触发会不会波及顶层的按钮呢?不会,因为按钮不能形成嵌套关系。
function openWin(url)
{
window.open(url);
}
</script>
下面是本人在网上抄的一个方法,把这个方法放在精准目标对象处理程序结尾,本事件触发处理结束后,事件将不在进行冒泡处理。
【阻止事件冒泡例子】
复制代码 代码如下:
<div onclick="showMsg(this,event)" id="outSide" style="width:100px; height:100px; background:#000; padding:50px">
<div onclick="showMsg(this,event)" id="inSide" style="width:100px; height:100px; background:#CCC"></div>
</div>
<script type="text/javascript">
//阻止事件冒泡后,你点击灰色盒子,整个过程只弹一次对话框了(注意与默认情况对比)
function showMsg(obj,e)
{
alert(obj.id);
stopBubble(e)
}
//阻止事件冒泡函数
function stopBubble(e)
{
if (e && e.stopPropagation)
e.stopPropagation()
else
window.event.cancelBubble=true
}
</script>
相关推荐:
GPT优化:让你的工作与生活更高效、更智能,Ai__79
AI上的文章属于原创吗?人工智能创作内容的归属问题
优化型网站:提升企业竞争力的必备利器,重庆网站推广工作如何
专业关键词助力SEO优化,让你的内容脱颖而出,东营响应式网站优化
seo网站页面优化包括什么,seo页面优化技术 ,no ai写作
专业SEO助力企业在激烈市场竞争中脱颖而出,嘉兴海外网站推广价格
GPT在什么时候被人熟知的?从技术突破到广泛应用的背后故事,ai商业新思维ai课程
实用AI工具:提升效率、优化生活的科技利器
一秒采集:提升效率、创造价值的秘密武器,苏州网站整站优化
ChatGPT:我目前无法查看或解析附件,您是否遇到过这样的困扰?,ai+燃烧
什么是seo网站推广,什么是seo网站推广 ,ai酷男人
SEO优化与SEM广告:提升品牌曝光与流量的双重利器,ai接回头
SEO数量-如何提升你的网站排名与流量?,射阳seo优化五星服务
优化入口:提升网站流量与转化率的秘密武器,琼海关键词排名品牌
SEO获取流量的必杀技:如何通过优化轻松提升网站排名,德州全网营销推广价格
优化原理:提升效率、创新突破的核心法则,印刷包装推广有哪里网站
为什么选择收录网站是企业在线营销的必备策略,全网营销与推广
SEO元素-提升网站排名的核心要素,推广分成网站有哪些
OpenAI推出的GPT-4Turbo大幅降低了AI应用成本,推动了AI技术的普及化,ai*版
ChatGPT:基于Transformer技术的语言模型,开创人工智能未来,AI独战OK
怎么用AI生成文章免费版,高效创作从此开始!
SEO符合:提升网站排名的秘诀,助力企业赢在搜索引擎优化的赛道,优化没续费 网站没了
用AI写文章,释放你的创作潜力!
ChatGPT页面无法下拉?禁用浏览器扩展,轻松解决!,imba 1.6 ai
用AI写一篇文章,如何提升你的写作效率与创意
文章缩写AI:高效编辑的未来之光
SEO和品牌营销:如何通过搜索引擎优化打造品牌影响力,建邺seo软件
SEO主要是为网站引流吗?深入解析SEO的核心价值,AI算算
AI写作免费一键生成下载,助您轻松创作!
seo追词是什么,seo词条 ,52580609AI
提升写作效率,释放创意潜力文章生成AI软件的未来
《权重参谋:让您的网站轻松登顶搜索引擎的秘密武器》,设计微信社群私域营销推广简案
seo都有什么问题,seo都有什么问题和答案 ,ai凯旋公主下载
AI文章精简-高效提炼与优化你的内容创作,ai quid
智能AI写文章:高效创作新风尚
seo要会些什么,seo需要学些什么内容 ,轻盈ai
洗文章AI:让内容创作变得更智能、更高效
AI网页效果生成:开启网站设计的新纪元,ai画线祥云
软件AI:颠覆未来的智能革命
文章AI思维导图自动生成助力创作的智慧之源
未来写作新模式文章撰写AI如何助力内容创作
SEO妍:搜索引擎优化的艺术,轻松打造网络营销新未来,辽宁网站建设贵不贵
AI撰写率:让创作变得更高效,助力内容产业腾飞,人力ai
SEO组织:让您的网站流量倍增的秘密武器,seo 绩效标准
ChatGPT网页打不开?快来看看这些解决办法,轻松恢复正常访问!,ai金色包装
SEO快速排名实例:如何通过实战技巧提升网站排名,快速突破流量瓶颈,安徽ai跑步机企业
ChatGPT怎么打开不了?全方位解决方案!,大庆ai
SEO包月服务:助力企业提升网站排名与流量的长期利器,网站建设流程 报读文库
怎么查一篇文章是不是AI写的?你需要这几个关键方法!
SEO运营工作是什么,seo公司运营 ,720516AI