美文网首页web
js中事件是如何传播的?

js中事件是如何传播的?

作者: 嘭嘭嘭鹏 | 来源:发表于2019-03-08 08:40 被阅读0次

小历史:

事件传播的不同还要从早先的两家浏览器巨头说起,网景和IE为了能争夺市场,互相使用相反的技术,当网景使用事件捕获流的时候,IE则使用事件冒泡流。后来W3C为了能规范规定,直接折中,当事件发生时,先发生向下传播,当到底了以后再次使用事件冒泡,逐渐的冒泡到根节点。

事件传播分三个阶段:

DOM事件流(event flow )存在三个阶段:事件捕获阶段、处于目标阶段、事件冒泡阶段。

  • 在事件捕获阶段,事件从document对象沿着文档树向下传播给目标节点。如果目标的任何一个祖先注册了捕捉事件句柄,那么在事件传播的过程中,就会运行这些句柄(IE10及以下不支持捕获型事件)。
  • 目标阶段发生在目标节点自身,这与0级事件模型提供的事件处理方法类似。
  • 事件冒泡阶段,在这个阶段,事件将从目标元素向上传播回(像冒泡)Document对象的文档层次(IE8 及以下没有捕获阶段)。


    事件传播示意图

无论是事件捕获还是事件冒泡,它们都有一个共同的行为,就是事件传播,它就像一跟引线,只有通过引线才能将绑在引线上的鞭炮(事件监听器)引爆,试想一下,如果引线不导火了,那鞭炮就只有一响了!!!

dom标准事件流的触发的先后顺序为:先捕获再冒泡,即当触发dom事件时,会先进行事件捕获,捕获到事件源之后通过事件传播进行事件冒泡。

事件监听

与这两个事件密切相关的是addEventListener、attachEvent:

addEventListener(event, listener, useCapture)

参数定义:
event---(事件名称,如click,不带on)
listener---事件监听函数
useCapture---是否采用事件捕获进行事件捕捉,默认为false,即采用事件冒泡方式
addEventListener在 IE11、Chrome 、Firefox、Safari等浏览器都得到支持。

attachEvent(event,listener)

参数定义:
event---(事件名称,如onclick,带on)
listener---事件监听函数。
attachEvent主要用于IE浏览器,并且仅在IE10及以下才支持,IE11已经不在使用这个方法。

阻止事件冒泡

w3c的方法是e.stopPropagation(),IE则是使用e.cancelBubble = true

evt.stopPropagation();
evt.cancelBubble = true;

在处理浏览器兼容问题时,可以这样:

if(evt.stopPropagation){
    evt.stopPropagation();
}else{
    evt.cancelBubble = true;
}

还有一种以阻止默认事件的方式去阻止冒泡行为

return false

区别

  • event.stopPropagation();
    事件处理过程中,阻止了事件冒泡,但不会阻击默认行为

  • return false;
    事件处理过程中,阻止了事件冒泡,也阻止了默认行为

  • event.preventDefault();
    它的作用是:事件处理过程中,不阻击事件冒泡,但阻击默认行为

————愿你在迷茫时,坚信你的珍贵,爱你所爱,行你所行,听从你心,无问西东。

相关文章

  • js中事件是如何传播的?

    小历史: 事件传播的不同还要从早先的两家浏览器巨头说起,网景和IE为了能争夺市场,互相使用相反的技术,当网景使用事...

  • JS 事件(2)

    1、事件传播机制、阻止传播、取消默认事件、事件代理这些到底是什么呢? ①事件传播机制:JS事件传播包括三个阶段: ...

  • js中的事件传播过程

    引子:父div添加监听事件,子div设置监听事件,点击子元素,会出现什么结果 事件传播的三个过程,事件捕获阶段、处...

  • js中的事件传播流程

    一 事件基础 JavaScript 事件是由访问 Web 页面的用户引起的一系列操作。当用户执行某些操作的时候,再...

  • js的事件传播

    事件的传播 关于事件的传播网景公司和微软公司有不同的理解, 微软公司认为事件应该是由内向外传播,也就是当事件触发...

  • 前端面试(一)

    一、事件传播流程 js事件传播流程主要分为三个阶段:事件捕获阶段、处于目标阶段、事件冒泡阶段。 二、Ajax轮询—...

  • HTML+JS事件捕获

    事件:JavaScript 和 HTML的交互是通过事件实现的,事件发生在传播过程中。 DOM中事件传播有2种方式...

  • netty源码分析(22)- outBound事件的传播

    上一节学习了inbound事件的传播,充分理解了在pipeline中是如何向一个个handler传播事件的,以ch...

  • js事件传播流程

    什么是JavaScript事件? 事件通常与函数配合使用,这样就可以通过发生的事件来驱动函数执行。js事件是由访问...

  • Vue构造器里面的选项:methods

    绑定事件的时候,如何传递事件对象event我们在平时写js代码的时候的绑定事件: 在vue中传递事件对象呢?是通过...

网友评论

    本文标题:js中事件是如何传播的?

    本文链接:https://www.haomeiwen.com/subject/pmrlpqtx.html