zoukankan      html  css  js  c++  java
  • 事件捕获与事件冒泡优先级

    【前言】

          DOM事件标准定义了两种事件流,这两种事件流有着显著的不同并且可能对你的应用有着相当大的影响。这两种事件流分别是捕获和冒泡。和许多Web技术一样,在它们成为标准之前,Netscape和微软各自不同地实现了它们,下面介绍DOM事件阶段以及事件捕获与事件冒泡先后执行顺序

    【主体】

    要做好兼容,除了依赖框架,我们得理解其基本原理。

    DOM事件三个阶段

    当一个DOM事件被触发时,它不仅仅只是单纯地在本身对象上触发一次,而是会经历三个不同的阶段:

    1.捕获阶段:先由文档的根节点document往事件触发对象,从外向内捕获事件对象;

    2.目标阶段:到达目标事件位置(事发地),触发事件;

    3.冒泡阶段:再从目标事件位置往文档的根节点方向回溯,从内向外冒泡事件对象。

     

    事件捕获与事件冒泡先后执行顺序就显而易见了。

    <!DOCTYPE html>
     <html lang="en">
     <head>
       <meta charset="UTF-">
       <title>Document</title>
       <style>
         #outer{
           text-align: center;
            px;
           height: px;
           background-color: #ccc;
           margin: auto;
         }
         #middle{
            px;
           height: px;
           background-color: #f;
           margin: auto;
         }
         #inner{
            px;
           height: px;
           background-color: #f;
           margin: auto;
           border-rad
         }
       </style>
     </head>
     <body>
       <div id='outer'>
         <span>outer</span>
         <div id='middle'>
           <span>middle</span>
           <div id='inner'>
             <span>inner</span>
           </div>
         </div>
       </div>
       <script>
         function $(element){
           return document.getElementById(element);
         }
         function on(element,event_name,handler,use_capture){
           if(addEventListener){
             $(element).addEventListener(event_name,handler,use_capture);
           }
           else{
             $(element).attachEvent('on'+event_name,handler);
           }
         }
         on("outer","click",o_click_c,true);
         on("middle","click",m_click_c,true);
         on("inner","click",i_click_c,true);
         on("outer","click",o_click_b,false);
         on("middle","click",m_click_b,false);
         on("inner","click",i_click_b,false);
         function o_click_c(){
           console.log("outer_捕获");
           alert("outer_捕获");
         }
         function m_click_c(){
           console.log("middle_捕获")
           alert("middle_捕获");
         }
         function i_click_c(){
           console.log("inner_捕获")
           alert("inner_捕获");
         }
         function o_click_b(){
           console.log("outer_冒泡")
           alert("outer_冒泡");
         }
         function m_click_b(){
           console.log("middle_冒泡")
           alert("middle_冒泡");
         }
         function i_click_b(){
           console.log("inner_冒泡")
           alert("inner_冒泡");
         }
       </script>
     </body>
     </html>

    .

  • 相关阅读:
    汇编指令记录
    nginx源码剖析(3)nginx中的内存池
    STL中的vector
    Direct3D学习笔记
    委托的作用
    vs2010 快捷键大全
    Web Service学习笔记:什么是Web Service
    [Serializable]在C#中的作用NET 中的对象序列化
    .NET中反射机制的使用与分析
    什么时候用WebService
  • 原文地址:https://www.cnblogs.com/fightjianxian/p/11104086.html
Copyright © 2011-2022 走看看