• 冒泡事件

    定义:当多个Dom元素互相嵌套的时候,一个元素触发了某个事件(例如Click事件),那么嵌套此事件的所有元素都会被触发一次Click事件,注意:只会触发他的直系亲属元素,而与其自己,父级,爷级等等同级的亲戚集是不会触发的

  • 捕获事件:

    *定义:** 同冒泡事件含义相似,只是将冒泡事件的触发顺序倒过来即可

  • DOM事件流

    元素的触发流程分为三个阶段

    1. 捕获阶段:先从祖先级一直找到触发的源元素(所有元素都触发了相同事件)

    2. 目标阶段:找到原元素,然后触发源元素的事件

    3. 冒泡阶段:然后重新流回祖先元素,又触发了一遍相同事件

  • 思考: 按照上面的事件流,岂不是一个元素会触发两次事件?那这不是很奇怪吗:其实在我们一般开发过程中都是用Jqueryon 方法来绑定的(推荐使用),绑定后,只会触发冒泡事件。那么什么时候会涉及到这个捕获阶段呢,在原生的javascript中,就会有此方法的使用,且看下面详解

  • 详解 addEventListener/removeEventListener

    作用: 原生的事件绑定方法


    // type:事件类型,不含"on",比如"click"、"mouseover"、"keydown";
    // 而attachEvent的事件名称,含含"on",比如"onclick"、"onmouseover"、"onkeydown";
    // listener:事件处理函数
    // useCapture是事件冒泡,还是事件捕获(true),默认false,代表事件冒泡类型
    addEventListener(type, listener, useCapture);

    特点:

    1. 一个元素可以同时绑定两种类型(捕获/冒泡)

    2. 一个同种类型的元素重复绑定同一个事件函数,只绑定一次

    3. 一个元素可以重复绑定多个不同的函数,且是叠加而非覆盖

  • 触发流程:

    1. 首先源目标触发了事件

    2. 开始捕获阶段,将其直系亲属(类型为捕获)的事件触发

    3. 到达源元素,触发事件方法,如果重复绑定多个,则按绑定顺序触发(源元素的类型其实没有影响)

    4. 然后开始冒泡排序,将其直系亲属(类型为冒泡)的事件触发

    <script>
    
        window.onload = function(){
    var outA = document.getElementById("outA");  
    var outB = document.getElementById("outB");  
    var outC = document.getElementById("outC");   // 目标(自身触发事件,是冒泡还是捕获无所谓)
    outC.addEventListener('click',function(){alert("target2");},true);
    outC.addEventListener('click',function(){alert("target1");},true); // 事件冒泡
    outA.addEventListener('click',function(){alert("bubble1");},false);
    outB.addEventListener('click',function(){alert("bubble2");},false); // 事件捕获
    outA.addEventListener('click',function(){alert("capture1");},true);
    outB.addEventListener('click',function(){alert("capture2");},true);
    }; </script> <body>
    <div id="outA" style="width:400px; height:400px; background:#CDC9C9;position:relative;">
    <div id="outB" style="height:200; background:#0000ff;top:100px;position:relative;">
    <div id="outC" style="height:100px; background:#FFB90F;top:50px;position:relative;"></div>
    </div>
    </div>
    </body>

    点击outC的时候,打印顺序是:capture1-->capture2-->target2-->target1-->bubble2-->bubble1

    结论:捕获阶段的处理函数最先执行,其次是目标阶段的处理函数,最后是冒泡阶段的处理函数。目标阶段的处理函数,先注册的先执行,后注册的后执行

  • 如何解决冒泡/捕获事件的影响

    目的: 我们很清楚,解决冒泡和捕获事件的影响,只需要在源元素触发完事件之后停止事件的传播即可

    方式:

    1. event.stopPropagation(); 只阻止了冒泡事件, 默认行为没有阻止(超链接a嵌套按钮,依然会跳转)

    2. event.preventDefault(); 只阻止了默认事件,冒泡事件没有阻止(超链接a嵌套按钮,不跳转,但会触发点击事件)

    3. return false; 冒泡事件和默认事件都阻止

    <script>
    
        window.onload = function(){
    var outA = document.getElementById("outA");  
    var outB = document.getElementById("outB");  
    var outC = document.getElementById("outC");   // 目标
    outC.addEventListener('click',function(event){
    alert("target");
    event.stopPropagation();
    },false); // 事件冒泡
    outA.addEventListener('click',function(){alert("bubble");},false); // 事件捕获
    outA.addEventListener('click',function(){alert("capture");},true); }; </script> <body>
    <div id="outA" style="width:400px; height:400px; background:#CDC9C9;position:relative;">
    <div id="outB" style="height:200; background:#0000ff;top:100px;position:relative;">
    <div id="outC" style="height:100px; background:#FFB90F;top:50px;position:relative;"></div>
    </div>
    </div>
    </body>
    capture-->target,不会打印出bubble。因为当事件传播到outC上的处理函数时,通过stopPropagation阻止了事件的继续传播,所以不会继续传播到冒泡阶段,当然如果此方法放到了捕获中,那么就只会打印出capture了
  • 注意点:

    今天用 on 绑定的时候,div 嵌套按钮,按钮里的事件触发带有ajax的请求,结果点击确实进入了按钮事件方法中,但是还没有进入回调函数,就跳转到div的点击事件方法中了,然后再跳回回调方法中,采用了以下方法解决


    <html>
    <head>
       <meta name="viewport" content="width=device-width" />
       <title>webApi测试</title>
       <script src="~/js/jquery.min.js"></script>
    </head>
    <body>
       <div id="first">
       </div>
       <div id="outA" style="width:400px; height:400px; background:#CDC9C9;position:relative;">
           <div id="outB" style="height:200; background:#0000ff;top:100px;position:relative;">
               <div id="outC" style="height:100px; background:#FFB90F;top:50px;position:relative;"></div>
           </div>
           </div>
       </div>
    </body>
    </html>

    <script>
       $(function () {

           $("#outC").on ("click",function () { alert("C")});
           $("#outB").on ("click",function () { alert("B") });
           $("#outA").on("click", function () { alert("A") });
           $("#outD").on("click", function () { alert("D") });

           $("#first").on("click", function () { debugger; alert("最外层div") });
           $("#routeTest").on("click", ajaxFunction);

           function ajaxFunction() {
               debugger;
               //event.cancelBubble = true;//取消事件的冒泡,效果同下
               //return false//此方法会导致此方法直接结束,因此不能直接使用
               event.stopPropagation();  
               $.ajax({
                   url: "/Course/GetCourseByRoute?temp"+Date.parse(new Date()),
                   type: 'get',
                   success: function (res) {
                       debugger;
                       alert(res);
                  }
              });
          }
      });
    </script>

javascript冒泡事件详解的更多相关文章

  1. Js冒泡事件详解及阻止

    Js冒泡机制是指如果某元素定义了事件A,如click事件,如果触发了事件之后,没有阻止冒泡事件,那么事件将向父级元素传播,触发父类的click函数. 如下例所示: <html>     & ...

  2. javascript之事件详解2

    1.事件对象: 在触发DOM事件的时候都会产生一个对象. 2.事件对象event: (1).type:获取事件类型 (2).target:获取事件目标 (3).stopPropagation():阻止 ...

  3. javaScript -- touch事件详解(touchstart、touchmove和touchend)

    HTML5中新添加了很多事件,但是由于他们的兼容问题不是很理想,应用实战性不是太强,所以在这里基本省略,咱们只分享应用广泛兼容不错的事件,日后随着兼容情况提升以后再陆续添加分享.今天为大家介绍的事件主 ...

  4. JavaScript——event事件详解

    1.事件对象 Event 对象代表事件的状态,比如事件在其中发生的元素.键盘按键的状态.鼠标的位置.鼠标按钮的状态. 什么时候会产生Event 对象呢? 例如: 当用户单击某个元素的时候,我们给这个元 ...

  5. JavaScript事件详解-jQuery的事件实现(三)

    正文 本文所涉及到的jQuery版本是3.1.1,可以在压缩包中找到event模块.该篇算是阅读笔记,jQuery代码太长.... Dean Edward的addEvent.js 相对于zepto的e ...

  6. JavaScript事件详解-Zepto的事件实现(二)【新增fastclick阅读笔记】

    正文 作者打字速度实在不咋地,源码部分就用图片代替了,都是截图,本文讲解的Zepto版本是1.2.0,在该版本中的event模块与1.1.6基本一致.此文的fastclick理解上在看过博客园各个大神 ...

  7. JavaScript事件详解-zepto的事件实现

    zepto的event 可以结合上一篇JavaScript事件详解-原生事件基础(一)综合考虑源码暂且不表,github里还有中文网站都能下到最新版的zepto.整个event模块不长,274行,我们 ...

  8. JAVASCRIPT事件详解-------原生事件基础....

    javaScirpt事件详解-原生事件基础(一)   事件 JavaScript与HTML之间的交互是通过事件实现的.事件,就是文档或浏览器窗口中发生的一些特定的交互瞬间,通过监听特定事件的发生,你能 ...

  9. JavaScript中的鼠标滚轮事件详解

    JavaScript中的鼠标滚轮事件详解/*Firefox注册事件*/ ~~~Firefox: addEventListener('DOMMouseScroll', handler, false)if ...

随机推荐

  1. Mysql安装、查看密码、修改密码、初始化、修改字符类型

    安装mysql 参照python篇一键安装lnmp.安装完之后再按照下面修改密码,修改配置文件,否则安装的时候就修改配置文件会出错. 注意:这也是二进制安装mysql.另一种二进制安装容易出错,生产环 ...

  2. laravel5.2总结

    转自:http://www.cnblogs.com/redirect/p/6178001.html

  3. vs2012编译的程序不能在XP和2003下执行问题的解决方法

    问题如题,通过无数次百度和谷歌后,发现,微软已经确认这是一个缺陷,安装Vs2012的update 3的升级包就可以解决问题.同时,在分发包的地方,vcredist_x86.exe 随程序分发一份就可以 ...

  4. iOS-CGAffineTransform相关函数

    CGAffineTransform相关函数 CGAffineTransformMakeTranslation(width, 0.0);是改变位置的,CGAffineTransformRotate(tr ...

  5. Touchpal实习技术栈和总结

    在TouchPal工作三个月了,人生的第一份互联网实习工作,小节一下工作中用到的相关技术和学到的东西(流水账哈哈哈) 1. linux系统 .包括VIM使用,log抓取统计.grep使用.定时cret ...

  6. php 大数组 foreach 循环嵌套的性能优化

    前提:最近在做后台的时候,页面加载太慢,故第一时间想到的自然是优化SQL, 优化后sql查询速度从 2秒变成了零点几秒, 以为就这麽完事了,然并卵,加载竟然花费30秒! 这麽慢,然后在代码中分块记录它 ...

  7. linux中的pvmove,pvremove,pvs,pvscan

    PV,VG,LV的关系和操作 PV,VG,LV构成了一种易于管理拥有一个或多个硬盘的主机的文件系统,这些硬盘可能只有一个分区也可能有多个.通过将这些物理存在的分区(或称为卷)PV(physical v ...

  8. nginx 为什么受欢迎?

    优势:1.高并发 2.可扩展性 3.高可靠性 4.热部署 5.BSD许可证 如何做到以上优势呢?高并发:异步io非阻塞,占用更少资源,支持更多连接可扩展:模块化设计,第三方模块多高可靠:核心框架代码的 ...

  9. [翻译向] 当flush privileges生效时

    #前言: 最近频繁在mysql权限控制这里栽跟斗,在翻阅了一些资料之后,简单地翻译一下官网关于flush privileges的描述,抛砖引玉.   #翻译正文: If the mysqld serv ...

  10. SQL,NoSQL和NewSQL

    一:概念 SQL(Structured Query Language):数据库,指关系型数据库.主要代表:SQL Server.Oracle.MySQL.PostgreSQL. NoSQL(Not O ...