Js事件处理模型/周期

  有3个阶段

1、  捕获阶段:由外向内,记录各级父元素上绑定的事件处理函数---只记录,不触发。

2、  目标触发:优先触发目标元素上的事件处理函数。

3、  冒泡:由内向外,按捕获的顺序的相反的方向,依次执行父元素上的事件处理函数。

过程如下图所示:

如果希望阻止某些冒泡行为,如表单验证失败时,不允许提交,可以使用e.stopPropagation();取消冒泡:

什么时候使用利用冒泡:

都知道,浏览器通过遍历方式查找事件处理函数执行。如果添加的事件监听越多,遍历越慢,网页响应速度越慢,因此

尽量少的添加事件监听.

如果多个平级子元素绑定相同事件时,可在父元素仅添加一个事件监听,所有子元素共用,并且使用e.target获取目标元素.

下面的代码是一个很经典的理解事件处理的例子:

这里,咱希望的是,点击那个div,那个就变黄,可是如果不加e.stopPropagation的话,在点击d3或d2时,都会冒泡执行其父元素的操作,

比如点击,最里面的d3,上面的d2,d1都会依次变黄.

<!DOCTYPE HTML>
<html>
    <head>
        <title>事件处理</title>
        <meta charset="utf-8"/>
         <style>
            .d1 .d2 .d3{cursor:pointer}
            .d1 {
              background-color: green;
              position: relative;
              width: 150px;
              height: 150px;
              text-align: center;
              cursor: pointer;
            }

            .d2 {
              background-color: blue;
              position: absolute;
              top: 25px;
              left: 25px;
              width: 100px;
              height: 100px;
            }

            .d3 {
              background-color: red;
              position: absolute;
              top: 25px;
              left: 25px;
              width: 50px;
              height: 50px;
              line-height: 50px;
            }

         </style>

    </head>
    <body>
        <div class="d1">
            <div class="d2">
                <div class="d3">
                </div>
            </div>
        </div>
    <script>
            function highLight(e){
        this.style.background="yellow";
        alert(this.className);
        this.style.background="";
        //取消冒泡  如果不加的话,在点击d3或d2时,都会冒泡执行其父元素的操作
        e.stopPropagation();
      }
            document.querySelector(".d1")
        .addEventListener(
          "click",highLight);
      document.querySelector(".d2")
        .addEventListener(
          "click",highLight);
      document.querySelector(".d3")
        .addEventListener(
          "click",highLight);
        </script>
    </body>
</html>
时间: 2024-10-17 13:29:36

Js事件处理模型/周期的相关文章

JS事件模型小结

08年年初的一篇blog,转到这个博客上,想想当年跨浏览器真是一座山: 前几天看dojo的文档,其中多次提到DOM2事件模型,以前学习这部分的内容,主要愤慨于IE的不兼容性了,现在对于DOM2事件模型的概念又有些模糊,所以翻出了js权威指南(V4)又复习了一下,简单作一小结.       JS权威指南中将JS事件模型分为四种            1.原始事件模型:属性事件处理模式            2.标准事件模型:DOM2对其作了标准化            3.IE事件模型(IE5.5

JS.【转】JS事件处理函数中return的作用

1.js事件处理函数中return的作用 - AnswerCard - 博客园.html(https://www.cnblogs.com/answercard/p/5255230.html) 2.网页内容保存: 这里面的return含有一些细节知识: 例如:onClick='return add_onclick()'与 onClick='add_onclick()'的区别 JAVASCRIPT在事件中调用函数时用return返回值实际上是对window.event.returnvalue进行设置

Tensoflw.js - 02 - 模型与内存管理(易懂)

Tensoflw.js - 02 - 模型与内存管理(易懂) 参考 W3Cschool 文档:https://www.w3cschool.cn/tensorflowjs/ 本文主要翻译一些英文注释,添加通俗的注释,记录新手使用遇到的小问题,去除不必要的部分,帮助新手快速入门 上一篇介绍了,Tensorflow.js 的安装,张量与变量的表示方法.创建和输出 Tensoflw.js - 01 - 安装与入门(中文注释) 本篇介绍模型与内存管理 Tensorflow.js 模型: 1.在 Tenso

JS线程模型&amp;Web Worker

js线程模型 客户端javascript是单线程,浏览器无法同时运行两个事件处理程序 设计为单线程的理论是,客户端的javascript函数必须不能运行太长时间,否则会导致web浏览器无法对用户输入做出响应.这也是为什么Ajax的API都是异步的,以及为什么客户端Javascript不能使用一个简单的异步load()或者require()函数来加载javascript库 如果应用程序不得不执行太多的计算而导致明显的延迟,应该允许文档在执行这个计算之前完全载入,并且确保告诉用户正在进行计算并且浏览

Android事件处理模型

事件处理是Android编程中非常重要的一个部分,因为Android应用在运行过程中会产生许多各种各样的事件(动作),应用必须为这些动作执行对应的响应代码:将产生的动作和响应联系起来的方式就是事件处理机制.Android平台提供了两种事件处理机制,分别是基于监听的模式和基于回调的模式. 1. 基于监听的事件处理模型 1.1 组成部分 事件源:事件发生的地方,比如某个按钮.文本框等 事件:事件类型,通过Event对象表达 事件监听器:负责监听某种的事件类型,并执行相应的操作 基于监听的事件处理模型

js盒子模型

1.js盒子模型 指的是通过js中提供的一系列的属性和方法,获取页面中元素的样式信息值 例: #box有很多自己的私有属性: HTMLDivElement.prototype->HTMLElement.prototype->Element.prototype->Node.prototype->EventTarget.prototype->Object.prototype var box = document.getElementById("box"); c

js事件处理 —— 详解

对于JS事件处理分为四部分: 1.html事件处理程序 直接添加到HTML结构中 解析:用html处理程序可以直接在button元素里直接调用,但是维护性不是很方便 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>Title</title> 6 7 </head> 8 &l

浅谈Node.js单线程模型

Node.js采用 事件驱动 和 异步I/O 的方式,实现了一个单线程.高并发的运行时环境,而单线程就意味着同一时间只能做一件事,那么Node.js如何利用单线程来实现高并发和异步I/O?本文将围绕这个问题来探讨Node.js的单线程模型: 1.高并发 一般来说,高并发的解决方案就是多线程模型,服务器为每个客户端请求分配一个线程,使用同步I/O,系统通过线程切换来弥补同步I/O调用的时间开销,比如Apache就是这种策略,由于I/O一般都是耗时操作,因此这种策略很难实现高性能,但非常简单,可以实

Java NIO 与 基于reactor设计模式的事件处理模型

Java NIO非堵塞应用通常适用用在I/O读写等方面,我们知道,系统运行的性能瓶颈通常在I/O读写,包括对端口和文件的操作上,过去,在打开一个I/O通道后,read()将一直等待在端口一边读取字节内容,如果没有内容进来,read()也是傻傻的等,这会影响我们程序继续做其他事情,那么改进做法就是开设线程,让线程去等待,但是这样做也是相当耗费资源的. Java NIO非堵塞技术实际是采取Reactor模式,或者说是Observer模式为我们监察I/O端口,如果有内容进来,会自动通知我们,这样,我们