首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

js事件防止冒泡

事件目标 如今。事件处理程序的变量event保存着事件对象。而event.target属性保存着发生事件的目标元素。这个属性是DOM API规定的,可是没有被全部浏览器实现 。...jQuery对这个事件对象进行了必要的扩展,从而在不论什么浏览器中都能够使用这个属性。通过.target,能够确定DOM首先接收到事件的元素(即实际被单击的元素)。...停止事件传播 事件对象还提供了一个.stopPropagation()方法,该方法能够全然阻止事件冒泡。...在这样的情况下,.preventDefault()方法则能够在触发默认操作之前终止事件 。 提示 当在事件的环境完毕了某些验证之后,一般会用到.preventDefault()。比如。...事件传播和默认操作是相互独立的两套机制,在二者不论什么一方发生时,都能够终止还有一方。假设想要同一时候停止事件传播和默认操作,能够在事件处理程序返回false。

2.4K40

解析Javascript事件冒泡机制

事件的阐述不是本文的重点,尚未了解的朋友,可以访问W3school教程 进行了解,这将有助于更好地理解以下的内容 。 2.冒泡机制 什么是冒泡呢?         ...在上升的过程,气泡会经过不同深度层次的水。 ? 相对应地:这个气泡就相当于我们这里的事件,而水则相当于我们的整个dom树;事件从dom 树的底层 层层往上传递,直至传递到dom的根节点。...为什么会出现上述的情况呢? 原因就在于事件冒泡,点击span的时候,span 会把产生的事件往上冒泡,作为父节点的div2 和 祖父节点的div1也会收到此事件,于是会做出事件响应,执行响应函数。...; } }); } 比较:          从事件传递上看:方法一在于取消事件冒泡,即当某些节点取消冒泡后,事件不会再传递;方法二在于不阻止冒泡,过滤需要处理的事件...通过以上方式,我们把本来每个元素都要有的处理函数,都交给了其祖父节点body 元素来完成了,也就是说,span,div2,div1 将自己的响应逻辑委托给body,让它来完成相应逻辑,自己不实现相应逻辑

57040

vue.js实现阻止事件冒泡

当父子元素中都有点击事件的时候,为了让触发子元素事件时,不去触发父元素事件,可以在子元素事件添加stop来阻止事件冒泡。....stop 是阻止冒泡行为,不让当前元素的事件继续往外触发,如阻止点击div内部事件,触发div事件 .prevent 是阻止事件本身行为,如阻止超链接的点击跳转,form表单的点击提交 .self 是只有是自己触发的自己才会执行...,如果接受到内部的冒泡事件传递信号触发,会忽略掉这个信号 .capture 是改变js默认的事件机制,默认是冒泡,capture功能是将冒泡改为倾听模式 .once 是将事件设置为只执行一次,如 .click.prevent.once...阻止click事件冒泡(防止触发另一个事件)的方法 使用vue阻止子级元素的click事件冒泡。...方法二 可以自己写个阻止冒泡事件 然后在发生冒泡的元素调用这个事件 @click="_stopPropagation($event)" methods:{ _stopPropagation

5.9K10

深入理解JavaScript事件传播机制事件冒泡事件捕获

前言在JavaScript事件冒泡事件捕获是两种不同的事件传播方式。当一个事件被触发时,它会从最内层的元素开始,然后逐级向外传播,直到最外层的元素。...在这个过程事件会经过每一个元素,直到它到达最内层的元素。在本文中,我们将详细了解事件冒泡事件捕获,并探讨它们在JavaScript的实现以及如何使用它们。...正文内容事件冒泡事件冒泡是指当一个事件被触发时,它会从最内层的元素开始,然后逐级向外传播,直到最外层的元素。在这个过程事件会经过每一个元素,直到它到达最外层的元素。...在事件冒泡事件处理程序会按照它们被注册的顺序执行,也就是说,先注册的事件处理程序会先执行。相反,在事件捕获事件处理程序会按照它们被注册的相反顺序执行,也就是说,后注册的事件处理程序会先执行。...在事件冒泡事件处理程序会按照它们被注册的顺序执行;在事件捕获事件处理程序会按照它们被注册的相反顺序执行。我正在参与2023腾讯技术创作特训营第四期有奖征文,快来和我瓜分大奖!

52021

JS事件流、事件冒泡、阻止冒泡事件捕获(一看就懂)

事件冒泡 、阻止冒泡事件捕获 之前先说说什么是事件流,这样会更容易明白 一、事件事件流 1、什么是事件 事件是可以被 JavaScript 侦测到的行为。...鼠标点击、鼠标移动、鼠标滚动、按下键盘,浏览器窗口大小的改变,网页加载完成,关闭网页等等都会发生事件。 2、什么是事件事件流,描述的是页面接受事件的顺序。...一个完整的JS事件流是从window开始,最后回到window的一个过程。 事件流被分为三个阶段(1~ 5)捕获过程、(5~ 6)事件触发过程、(6~ 10)冒泡过程。...三、阻止冒泡 1、JS阻止事件冒泡 我们用 e.stopPropagation() 这个方法添加到某事件函数里的末尾,就可以做到阻止冒泡事件。...事件句柄在冒泡阶段执行 从上面的表格,可以看到参数值useCapture,为true的时候,事件在捕获过程中就会执行。

10.3K53

JS事件冒泡和捕获

事件机制 ---- 事件触发三个阶段: window往事件触发处传播,遇到注册的捕获事件会触发 传播到事件触发处时触发注册的事件事件触发处往window传播,遇到注册的冒泡事件会触发 事件触发一般会按照...|------------------------------------------- 但是有一个特例:如果给body的子节点同时注册冒泡和捕获事件事件触发会按照注册的顺序执行。...// 以下会先打印冒泡然后是捕获node.addEventListener( 'click', event => { console.log('冒泡') }, false)node.addEventListener...'}, true) 当点击innner元素时,如下元素发生了: 点击事件开始于捕获阶段,在此阶段浏览器会在所有祖先元素上查找点击事件处理函数(从document开始) 结果找到了2个,分别在document...此时进入冒泡阶段,inner上的时间处理器得到执行 事件命中元素后开始向上冒泡,一路查找是否注册了冒泡阶段的祖先元素上的时间处理器。由于没有找到因此什么也没发生。

2.5K20

JavaScript系列之事件冒泡机制简介

JavaScript系列之事件冒泡机制 DOM事件流(event flow )存在三个阶段:事件捕获阶段、处于目标阶段、事件冒泡阶段,事件冒泡顺序是由内到外进行事件传播,事件冒泡是由IE开发团队提出来的...,即事件开始时由最具体的元素(文档嵌套层次最深的那个节点)接收,然后逐级向上传播。...听了简介介绍之后,您可能不理解,所以举个例子: js事件冒泡测试 <div id='content' onclick...最近也遇到了这种情况,所以就去网上搜索资料,简单学习一下,就是点击一个按钮的时候,竟然触发了两次,通过排查,发现了冒泡机制导致的,解决方法是禁用事件冒泡机制 w3c的方法是e.stopPropagation...todo }) 参考资料: JavaScript 详说事件机制冒泡、捕获、传播、委托:https://www.cnblogs.com/bfgis/p/5460191.html

53020

事件监听函数,以及事件的捕获和冒泡机制

事件经过的所有节点都会受到事件的影响,这个传播过程被称为DOM事件流 true是捕获,false是冒泡,默认为冒泡事件 1.addEventListener()--添加事件监听函数 给元素添加一个事件...,但是要知道它代表的意思 用布尔值来表示,true或者false,默认是false true表示在捕获阶段调用事件处理程序 false表示在冒泡阶段调用事件处理程序 根据图片可以看出,捕获阶段要先于冒泡阶段..."); } 1.优点:事件处理程序的代码,能够访问全局作用域中的任何变量 2.缺点:时差问题、扩展的作用域链在不同浏览器中会导致不同结果、html代码与js代码高度耦合 DOM0...= function test() { alert("DOM0级事件处理程序"); } 1.优点:代码简单,浏览器兼容性好,解决了html代码和js代码的高度耦合问题...2.缺点:一个元素只能绑定一个事件处理函数,只会在事件冒泡运行 DOM2级事件处理程序 该级别的事件处理程序,运用的就是事件捕获和冒泡机制 测试

1.2K10

js事件机制

什么是事件流 在JavaScript事件流是指一个事件沿特定数据结构传播的一个过程。整个事件流总共包含三个阶段(从dome2来说):1.事件捕获阶段、2.处于事件目标阶段、3.事件冒泡阶段。...从这个图里面我们可以清晰的看到整个事件流的执行过程,首先是从window开始,一步步的从上向下执行,此过程就是事件捕获阶段,当到达了事件的位置以后则处于事件目标阶段,之后会在向上冒泡,进入事件冒泡阶段...触碰完成以后再把手拿出来,正好是一个相反的过程,这就与我们的事件机制是一个道理。 事件绑定 下面来看一下下面这个示例代码: <!.../冒泡,bubbles为true才能使用 2 stopImmediatePropagation 取消事件进一步冒泡,并且组织任何事件处理程序被调用 3 在事件程序,this和currentTarget...,所应用的就是事件冒泡

1.5K20

JS事件,你真的懂吗(捕获,冒泡)?

说到js事件大家肯定都知道,那么今天讲一点大家不知道的(假设大家不知道?)。 所有的js事件都会分为两个阶段捕获和冒泡。...最后是outer冒泡阶段 由此我们可以看到,事件触发的时候实际上都是有捕获和冒泡阶段的,并且捕获阶段会从最外层的父级元素开始捕获,一直捕获到最后触发事件的那个元素点才会停止,那么冒泡阶段反之,会从最内层触发的那个元素开始往外层的父级元素一直冒泡...并且事件的触发是先捕获,在冒泡。 阻止事件冒泡 事件冒泡会让我们实现某些功能的时候产生阻碍,那么我们怎么怎么阻止事件冒泡呢,这个时候就会用到一个方法。...这样就成功的阻止了事件冒泡,是不是很神奇,那么我们阻止事件冒泡还有别的方法吗,答案是肯定的,这时候就得了解一下我们的event对象了,我们打印一下event对象,如下: 打印发现当我们触发事件时,...我们在使用多数情况下只使用冒泡监听。例如一条购物车信息,在这条信息,右下角有一个删除按钮。点击这条消息可查看详情,点击删除按钮可将此商品移除。

2.2K20
领券