• 注册
当前位置:1313e > 默认分类 >正文

面试整理之DOM事件阶段

因为快面试了,打开《JavaScript高级程序设计》,对DOM事件进行整理了下

本文主要解决的问题:

  1. 事件流
  2. DOM事件流的三个阶段

先理解流的概念

在现今的JavaScript中随处可见。比如说React中的单向数据流,Node中的流,又或是今天本文所讲的DOM事件流。都是流的一种生动体现。用术语说流是对输入输出设备的抽象。以程序的角度说,流是具有方向的数据。

事件流分事件冒泡与事件捕获

在浏览器发展的过程中,开发团队遇到了一个问题。那就是页面中的哪一部分拥有特定的事件?

可以想象画在一张纸上的一组同心圆,如果你把手指放在圆心上,那么你的手指指向的其实不是一个圆,而是纸上所有的圆。放到实际页面中就是,你点击一个按钮,事实上你还同时点击了按钮所有的父元素。
开发团队的问题就在于,当点击按钮时,是按钮最外层的父元素先收到事件并执行,还是具体元素先收到事件并执行?所以这儿引入了事件流的概念。

通俗说,事件流所描述的就是从页面中接受事件的顺序。

因为有两种观点,所以事件流也有两种,分别是事件冒泡和事件捕获。现主流是事件冒泡。

 

事件冒泡

事件冒泡即事件开始时,由最具体的元素接收(也就是事件发生所在的节点),然后逐级传播到较为不具体的节点。

下面写个例子:

 1 DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4   <meta charset="UTF-8">
 5   <title>Event Bubblingtitle>
 6 head>
 7 <body>
 8   <button id="clickMe">Click Mebutton>
 9 body>
10 html>

然后,我们给button和它的父元素,加入点击事件。

 1 var button = document.getElementById('clickMe');
 2 
 3 button.onclick = function() {
 4   console.log('1. You click Button');
 5 };
 6 document.body.onclick = function() {
 7   console.log('2. You click body');
 8 };
 9 document.onclick = function() {
10   console.log('3. You click document');
11 };
12 window.onclick = function() {
13   console.log('4. You click window');
14 };

在Chrome浏览器运行:

如果点击了button,那么这个点击事件会按如下的顺序传播

  1. button
  2. body
  3. document
  4. window

也就是说,click事件首先在

转载于:https://www.cnblogs.com/LIUYANZUO/p/5332583.html

本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 162202241@qq.com 举报,一经查实,本站将立刻删除。

最新评论

欢迎您发表评论:

请登录之后再进行评论

登录