Javascript事件冒泡,没有想象中那么糟糕

Javascript事件冒泡,没有想象中那么糟糕


 提到js事件,我们可能第一时间反应的就是“如何阻止事件冒泡”;但是事件冒泡真的是如我们想象的那么糟糕吗?

1. Event 对象

 Event 对象代表事件的状态,比如事件在其中发生的元素、键盘按键的状态、鼠标的位置、鼠标按钮的状态。

2. 事件句柄 (Event Handlers)

 指能够使 HTML 事件触发浏览器中的行为,比如点击(onclick)、鼠标悬浮(onfocus)等

3. 什么是事件冒泡

 一个对象(event.srcElement||event.target)的事件被触发后,首先会执行这个事件的处理程序,然后会向这个对象的父级对象传播;顺序由内到外,由下向上,直到顶层(window对象)

来个栗子

 1 <body>
 2         <div class="mydiv" style="width:100%;height:50px;border:1px solid #d1d1d1">
 3             <input class="mybtn" type="button" value="Click Me">
 4         </div>
 5     </body>
 6     <script type="text/javascript">
 7     $(function(){
 8         $(document).on(‘click‘,‘input.mybtn‘,function(e){
 9             console.info("this is btn");
10         });
11
12         $(document).on(‘click‘,‘div.mydiv‘,function(e){
13             console.info("this is div");
14         });
15
16         $(document).on(‘click‘,‘body‘,function(e){
17             console.info("this is body");
18         });
19     });
20     </script>

 这里的结构从下到上分别是input[class=‘mybtn‘]->div[class=‘mydiv‘]->body ,通过jquery来绑定各自的点击事件。
点击一下看效果,依次点击body、button、div:

4.事件冒泡有什么作用

  1. 事件冒泡允许多个操作被集中处理(把事件处理器添加到一个父级元素上,避免把事件处理器添加到多个子级元素上),也可以理解为多个对象执行同一个事件
继续上栗子

 1 <body class="this is body">
 2         <div class="mydiv"  style="width:100%;height:50px;border:1px solid #d1d1d1">
 3             <input class="mybtn" type="button" value="Click Me">
 4             <span class="myspan1" style="margin:10px;border:1px red solid;">span1</span>
 5             <span class="myspan2" style="margin:10px;border:1px red solid;">span2</span>
 6         </div>
 7     </body>
 8     <script type="text/javascript">
 9     $(function(){
10         $(document).on(‘click‘,‘input.mybtn‘,function(e){
11             console.info("this is btn");
12         });
13
14         $(document).on(‘click‘,‘div.mydiv‘,function(e){
15             console.info("Class is "+ e.target.className);
16             // TODO:do something
17             return false;
18         });
19
20         $(document).on(‘click‘,‘body‘,function(e){
21             console.info("this is body");
22         });
23     });
24     </script>

这里在div[class=‘mydiv‘]中加入2个span标签,没有单独给span绑定点击事件,只是通过冒泡来统一处理点击事件。

5. 阻止事件冒泡

 事件的传播是可以阻止的

  1. 当前方法执行完后return false,来阻止事件的传播,像上面的栗子;
  2. 通过w3c调用浏览器方法来阻止
    1 if (e && e.stopPropagation)
    2          e.stopPropagation();
    3      else
    4          window.event.cancelBubble=true;//IE专用 
  3. 阻止a标签事件的默认行为,经常会遇到给超链接绑定事件,但是事件执行完成后,浏览器还是会跳转到新的页面。
    <a href="https://www.baidu.com" onclick="testa();return false;">点我</a>

    这个是一种比较挫的写法

    1 $(document).on(‘click‘,‘a‘,function(e){
    2          console.info("this is a");
    3          return false;
    4      });
    5 $("a").on("click",function(e){
    6          console.info("this is a");
    7          return false;
    8      });

    用jquery绑定事件就不用有类似的麻烦。

    1 function testa()
    2  {
    3      console.info("this is a");
    4      window.event.returnValue = false;//FF不支持这种写法
    5  }

  4. blur、focus、load、unload这些事件不会向父级传播
时间: 2024-08-25 06:47:45

Javascript事件冒泡,没有想象中那么糟糕的相关文章

解析Javascript事件冒泡机制

本资源引自: 解析Javascript事件冒泡机制 - 我的程序人生 - 博客频道 - CSDN.NET http://blog.csdn.net/luanlouis/article/details/23927347 ----------------------------------------------------------------------------------------------------------------------------------------- 1.

转:JavaScript事件冒泡简介及应用

(本文转载自别处) JavaScript事件冒泡简介及应用 一.什么是事件冒泡 在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象传播,从里到外,直至它被处理(父级对象所有同类事件都将被激活),或者它到达了对象层次的最顶层,即document对象(有些浏览器是window). 打个比方说:你在地方法院要上诉一件案子,如果地方没有处理此类案件的法

JavaScript事件冒泡和事件委托

JavaScript事件冒泡和事件委托 付建宇 - 2 条评论 接触JavaScript不久,学的东西也不是特别多.小雨就是习惯把平时学到的东西拿出来分享.一方面加强自己的印象,一方面可以让自己的经验为他人答疑解惑.我们知道JavaScript可以监控页面上元素的各种事件,常用的事件有很多,例如点击,鼠标移入.移出,元素改变等等.这次主要说一下事件冒泡及其一个比较酷的应用,事件委托.不做特殊说明,以下都在jQuery框架内执行. 事件冒泡 什么是“事件冒泡”呢?假设这里有一杯水,水被用某种神奇的

Javascript 事件冒泡

先来看个Javascript 事件冒泡的例子. 在div 元素中有一个button,他们都绑定了一个click事件,这是能够产生事件冒泡的前提.当你 单击button的时候,会弹出两个警告框,一个是button的click事件引起的,另一个是div的click事件产生的. 你只单击了button,div的元素也触发了click事件,这就是事件冒泡引起的. <html> <head> <title>event bubble sample</title> <

解析Javascript事件冒泡机制(转) 本文转自:http://blog.csdn.net/luanlouis/article/details/23927347

本文转自:http://blog.csdn.net/luanlouis/article/details/23927347 1. 事件 在浏览器客户端应用平台,基本生都是以事件驱动的,即某个事件发生,然后做出相应的动作. 浏览器的事件表示的是某些事情发生的信号.事件的阐述不是本文的重点,尚未了解的朋友,可以访问W3school教程 进行了解,这将有助于更好地理解以下的内容 . 2. 冒泡机制 什么是冒泡呢? 下面这个图片大家应该心领神会吧,气泡从水底开始往上升,由深到浅,升到最上面.在上升的过程中

JavaScript事件——冒泡、捕获

本节要点:1.干预系统的事件处理机制(一)DOM事件流 (二)停止事件冒泡 (三)阻止事件的默认行为 1.干预系统的事件处理机制 (一)DOM事件流 DOM模型是一个树形结构,在DOM模型中,HTML元素是有层次的.当一个HTML元素上产生一个事件时,该事件会在DOM树中元素节点与根节点之间按特定的顺序传播,路径所经过的节点都会收到该事件,这个传播过程就是DOM事件流. DOM事件标准定义了两种事件流,分别是捕获事件和冒泡事件. 1.冒泡事件流 默认情况下,事件使用冒泡事件流.当事件(例如单击事

javascript事件冒泡

1. 事件 在浏览器客户端应用平台,基本生都是以事件驱动的,即某个事件发生,然后做出相应的动作. 浏览器的事件表示的是某些事情发生的信号.事件的阐述不是本文的重点,尚未了解的朋友,可以访问W3school教程 进行了解,这将有助于更好地理解以下的内容 . 2.冒泡机制 什么是冒泡呢? 下面这个图片大家应该心领神会吧,气泡从水底开始往上升,由深到浅,升到最上面.在上升的过程中,气泡会经过不同深度层次的水. 相对应地:这个气泡就相当于我们这里的事件,而水则相当于我们的整个dom树:事件从dom 树的

Javascript事件冒泡机制

1. 事件 在浏览器客户端应用平台,基本生都是以事件驱动的,即某个事件发生,然后做出相应的动作. 浏览器的事件表示的是某些事情发生的信号.事件的阐述不是本文的重点,尚未了解的朋友,可以访问W3school教程 进行了解,这将有助于更好地理解以下的内容 . 2.冒泡机制 什么是冒泡呢? 下面这个图片大家应该心领神会吧,气泡从水底开始往上升,由深到浅,升到最上面.在上升的过程中,气泡会经过不同深度层次的水. 相对应地:这个气泡就相当于我们这里的事件,而水则相当于我们的整个dom树:事件从dom 树的

JavaScript事件冒泡简介及应用

一.什么是事件冒泡 在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事 件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象传播,从里到外,直至它被处理(父级对象所有同类事件都将被激活),或者它到达了对 象层次的最顶层,即document对象(有些浏览器是window). 打个比方说:你在地方法院要上诉一件案子,如果地方没有处理此类案件的法院,地方相关部门会帮你继续往上级法院上诉,比如从市级到省