详解javascript事件冒泡_javascript技巧
事件是javascript中的核心内容之一,在对事件的应用中不可避免的要涉及到一个重要的概念,那就是事件冒泡,在介绍事件冒泡之前,先介绍一下另一个重要的概念事件流:
一.什么是事件流:
文档对象模型(DOM)是一个树形结构,可以形象的用下图表示。
如果一个html元素触发事件,那么这个事件就会在DOM树中的触发节点和根节点之间按照一定的顺序传播,所有经过的节点都会接收到被触发的事件,这个传播过程被称之为事件流。按照事件的传播顺序,可以将其分为两类,一种是事件冒泡,一种是事件捕获,这里就涉及到本章要介绍的主题了:
1.事件冒泡:
所谓的时间冒泡就是当一个元素触发一个事件,事件会像是水泡一样,从触发元素向它的所有父节点传播,一直到根节点都会接收到此事件,如果父元素中注册了相应的事件处理函数,那么尽管事件在子节点触发的,在父元素上注册的事件处理函数同样会被触发。例如在上面图示中,如果触发a元素的onclick事件,那么它的父元素p、document和widow都会接收到此事件,并且如果在相应的父元素注册有时间处理函数,那么此事件处理函数将会执行,看一段代码实例:
<html> <head> <meta charset="utf-8"/> <title>事件冒泡简单介绍</title> <script type="text/javascript"> window.onload=function(){ var table=document.getElementById("mytable"); table.onclick=function(e){ var event=e||window.event; target=event.srcElement||event.target; alert(target.innerHTML); } } </script> </head> <body> <table width="400" border="1" id="mytable"> <tr> <td>脚本之家</td> <td>脚本之家</td> <td>脚本之家</td> </tr> <tr> <td>脚本之家</td> <td>脚本之家</td> <td>脚本之家</td> </tr> <tr> <td>脚本之家</td> <td>脚本之家</td> <td>脚本之家</td> </tr> </table> </body> </html>
以上代码的目的是,当点击相应的单元格的时候就会弹出对应单元格中的内容。但是在上面的实现中并不是为每一个单元格注册onclick事件处理函数,而是将onclick事件处理函数注册于单元格的父元素table上,当点击单元格的时候会触发onclick事件,事件还会从从事件对象向上传播,而table元素恰好有注册的onclick事件处理函数,这个时候就会执行此处理函数,当然这里会设置到传递事件对象参数的问题。所有的浏览器都支持事件冒泡。二.事件捕获:
事件捕获和事件冒泡恰好相反,当点击一个元素的时候,事件传播的方向是从根元素到触发元素,IE浏览器并不支持,为了跨浏览器支持,所以默认情况下一般都是使用冒泡型事件处理模型。
2.javascript阻止事件冒泡代码
事件冒泡在某些场景非常的有用,但是有时候也是必须要阻止,下面是一段能够兼容所有主流浏览器的阻止事件冒泡的实例代码。
代码实例:
function stopBubble(e) { if(e&&e.stopPropagation) { e.stopPropagation(); } else { window.event.cancelBubble=true; } }
以上代码可以阻止事件冒泡,下面对代码做一下简单注释:
二、代码注释:
- 1.function stopBubble(e) {},此函数用来阻止事件冒泡,参数是个事件对象。
- 2. if(e&&e.stopPropagation){e.stopPropagation();},判断是否支持stopPropagation,如果支持就使用e.stopPropagation()。stopPropagation()函数IE10和IE10以下浏览器不支持。
- 3.window.event.cancelBubble=true,当前IE浏览器使用这个可以阻止事件冒泡。
以上就是关于javascript事件冒泡的详细介绍,希望对大家的学习有所帮助。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

理解事件冒泡:为什么子元素的点击会触发父元素的事件?事件冒泡是指在一个嵌套的元素结构中,当子元素触发某个事件时,该事件会像冒泡一样逐层传递到父元素,直至最外层的父元素。这种机制使得子元素的事件可以在整个元素树中传递,并依次触发所有相关的元素。为了更好地理解事件冒泡,让我们来看一个具体的示例代码。HTML代码:<divid="parent&q

JavaScript 中的点击事件不能重复执行,原因在于事件冒泡机制。为了解决此问题,可以采取以下措施:使用事件捕获:指定事件侦听器在事件冒泡之前触发。移交事件:使用 event.stopPropagation() 阻止事件冒泡。使用计时器:在一段时间后再次触发事件侦听器。

标题:jQuery.val()失效的原因及解决方法在前端开发中,经常会使用jQuery来操作DOM元素,其中.val()方法被广泛用于获取和设置表单元素的值。然而,有时候我们会遇到.val()方法失效的情况,导致无法正确获取或设置表单元素的值。本文将探讨造成.val()失效的原因,并提供相应的解决方法,同时附上具体的代码示例。1.原因分析.val()方法

事件冒泡为何会触发两次?事件冒泡(EventBubbling)是指在DOM中,当一个元素触发了某个事件(例如点击事件),该事件会从该元素开始向上冒泡至父元素,直到冒泡到最顶层的文档对象为止。事件冒泡是DOM事件模型的一部分,它允许开发者将事件监听绑定到父元素,从而在子元素触发事件时,可以通过冒泡机制来捕获并处理事件。然而,有时开发者会遇到事件冒泡触发两次的

Vue.js 事件修饰符用于添加特定行为,包括:阻止默认行为 (.prevent)停止事件冒泡 (.stop)一次性事件 (.once)捕获事件 (.capture)被动的事件监听 (.passive)自适应修饰符 (.self)关键修饰符 (.key)

事件冒泡是什么?深入解析事件冒泡机制事件冒泡是Web开发中一个重要的概念,它定义了页面上事件传递的方式。当一个元素上的事件被触发时,事件将会从最内层的元素开始传递,逐级向外传递,直到传递到最外层的元素。这种传递方式就像水泡在水中冒泡一样,因此被称为事件冒泡。在本篇文章中,我们将深入解析事件冒泡机制。事件冒泡的原理可以通过一个简单的例子来理解。假设我们有一个H

JS事件中有哪些不会冒泡的情况?事件冒泡(EventBubbling)是指在触发了某个元素的事件后,事件会从最内层元素开始沿着DOM树向上传递,直到最外层的元素,这种传递方式称为事件冒泡。但是,并不是所有的事件都能冒泡,有一些特殊情况下事件是不会冒泡的。本文将介绍在JavaScript中有哪些情况下事件不会冒泡。一、使用stopPropagati

不会冒泡的JS事件有哪些?JavaScript是一种强大的脚本语言,它为网页增加了交互性和动态性。在JavaScript中,事件驱动编程是非常重要的一部分。事件是指用户在网页上进行的各种操作,比如点击按钮、鼠标移动、键盘输入等等。JavaScript通过事件处理函数来响应这些事件,并进行相应的操作。在事件处理过程中,事件冒泡是一种常见的机制。事件冒泡是指当一
