冒泡与捕获事件

一.冒泡与捕获

1.概念。

冒泡事件:微软公司提出的,事件由子元素传递到父元素的过程叫做冒泡(false)。

捕获事件:网景公司提出的,事件由父元素传递到子元素的过程叫做事件捕获(ture)。

2.冒泡事件与捕获事件的区别

冒泡事件:事件从子级向父级传递。捕获事件:事件从父级传递向子级。

这里我用代码给大家进行一下解释:
首先有三个div  层级分别为d1>d2>d3。为他们分别添加点击事件,当我们点击d1,只会打印d1

但当我们点击d2 打印结果依次为 

这就是冒泡排序,事件从子级向父级传递。

 在捕获事件触发的前提,我们需要使用事件监听 document.addEventListener('event',funciton(){},true)  这里的true是布尔值判断是否为捕获事件,当为true时,这里为捕获事件,如果为false时,这里就是冒泡事件。用代码给大家解释一下:

 当我们点击d1时,打印d1.但是当我们点击d3时,打印结果依次为d1 d2 d3

 结果由父级传递向子级,这个过程称为捕获事件。

二.阻止冒泡与阻止默认

1.阻止冒泡就是让我们的层级事件不再触发,在点击子级时,父级不会触发点击事件。一般我们使用e.stoppropagation();来阻止冒泡。用代码解释一下: 这里给d3添加了阻止冒泡事件,所以我们在点击d3时,不会再打印d2 d1,只打印d3.

2.阻止默认:一般我们在文档中想复制一些文字,按住就可以勾选,但是当我们使用了阻止默认,内容就无法勾选。通常我们使用e.preventDefault()方法来阻止默认。

3.总结:e.stoppropagation()阻止冒泡  e.preventDefault()阻止默认  return false;既阻止冒泡又阻止默认。

三、addEventListener 的第三个参数

1.addEventListener(),接收3个参数

        第一个参数event:监听的事件

        第二个参数是函数:需要执行的事

        第三个参数是useCapture(变量):用来判断是捕获还是冒泡

2.第三个参数userCapyure

(1)当useCapture为true的时候是在捕获阶段触发事件 (捕获事件触发顺序是由父到子)

(2)当useCapture为false的时候是在冒泡阶段触发事件(默认为false)(冒泡事件触发顺序是由子到父)

四、取消监听函数

 五、onclick和addEventListener('click',handler)的区别
1:同时绑定多个事件

我们来想一个问题,我们使用onclick方法可不可以给一个按钮绑定多个事件呢?
我们来尝试一下:

    <button id="btn">点击</button>
    <script>
        btn.onclick = function(){
            console.log('第一次点击');
        }
        btn.onclick = function(){
            console.log('第二次点击');
        }
    </script>

 

然后我们来看一下结果是否两次都打印出来了:

可以看到只有第二次生效了,说明通过这种方法第二次绑定事件会将第一次覆盖!

现在我们来用第二种方法:

  <button id="btn">点击</button>
    <script>
        btn.addEventListener('click',()=>{console.log('第一次点击');},false);
        btn.addEventListener('click',()=>{console.log('第二次点击'),false});
    </script>


我们来看一下运行结果:

OK,可以看到通过这种方式我们是可以进行多次绑定事件的。

2:决定事件触发顺序

我们看一下代码

  <div id="div1">
        <button id="btn">点击</button>
    </div>
    <script>
        div1.onclick = function(){
            console.log('div1的事件');
        }
        btn.onclick = function(){
            console.log('btn的事件');
        }
    </script>


想一下如果我们点击了按钮,打印的顺序应该是什么样子的呢?

可以看到是从内而外,是以事件冒泡的方式来执行的。

而如果使用另一种方法:

   <div id="div1">
        <button id="btn">点击</button>
    </div>
    <script>
        btn.onclick = function(){
            console.log('btn的事件');
        }
        div1.addEventListener('click',()=>{console.log('div1的事件');},true);
    </script>


我现在把div1的事件通过addEventListener的方式来绑定,并且给第三个参数设置为true。
那么结果就是这样的:

所以我们通过第二种方法我们可以决定DOM事件的触发是以事件捕获的事件流还是事件冒泡的事件流方式。

3:removeEventListener的使用方法


这个方法就是删除DOM指定的事件,如果我们删除onclick的话,直接将onclick的值设置为null就可以了。
那这个方法如何删除呢?我们来看一下代码:

 

  div1.addEventListener('click',()=>{console.log('div1的事件');},true);
  div1.removeEventListener('click',()=>{console.log('div1的事件');},true);


这样做的话我们是否能将这个事件删除呢?答案是否定的,我们的两个事件处理程序虽然代码是一样的,但是它们确确实实不是一个事件处理程序,如果我们想要删除掉某个事件,我们必须这样做:

   

    var fn = function(){
          console.log('div1的事件');
      }
     div1.addEventListener('click',fn,true);
     div1.removeEventListener('click',fn,true);


只有这样才能确定两个方法所用的为一段事件处理程序,也是有效的删除方法。

  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在Vue中,事件冒泡事件捕获与原生的事件冒泡事件捕获机制相类似。事件冒泡指的是当一个元素触发了某个事件时,事件会从当前元素开始逐级向上冒泡,直到达到根元素(通常是document对象)为止。换句话说,事件会先在最内层的元素上触发,然后在父元素上触发,再在父元素的父元素上触发,依此类推,直到达到根元素。 事件捕获事件冒泡相反,它从根元素开始,逐级向下捕获,直到达到真正触发事件的元素。首先事件会在根元素上触发,然后在根元素的子元素上触发,再在子元素的子元素上触发,依此类推,直到达到触发事件的元素。 在Vue中,默认情况下,事件是通过事件冒泡机制来处理的。这意味着当你在子组件中触发一个事件时,它会向上传递到父组件,直到根组件。你可以使用修饰符`.stop`来停止事件冒泡,例如`@click.stop`。 然而,在特定情况下,你可能希望使用事件捕获机制来处理事件。Vue提供了一个修饰符`.capture`,可以让你在父组件中捕获事件,而不是默认的事件冒泡。例如,你可以使用`@click.capture`来在父组件中捕获子组件触发的点击事件。 总结起来,Vue中的事件冒泡事件捕获与原生的事件冒泡事件捕获机制相似,你可以根据需要选择使用事件冒泡还是事件捕获来处理事件。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Vue事件捕获事件冒泡](https://blog.csdn.net/weixin_43465508/article/details/131389975)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [vue绑定的点击事件阻止冒泡的实例](https://download.csdn.net/download/weixin_38723373/13203083)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

圆周率呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值