最近这段时间因为每天要修改网站,为网站做特效,所以看了很多的js接触事件,自己只会使用一小部分,有时用的时候也比较混乱,现在系统的整理了一下,首先跟大家在马海祥博客上跟大家分享的是JavaScript事件处理程序的3种方式:

一、什么是JavaScript事件?

事件(Event)是JavaScript应用跳动的心脏,也是把所有东西粘在一起的胶水,当我们与浏览器中Web页面进行某些类型的交互时,事件就发生了。

事件可能是用户在某些内容上的点击、鼠标经过某个特定元素或按下键盘上的某些按键,事件还可能是Web浏览器中发生的事情,比如说某个Web页面加载完成,或者是用户滚动窗口或改变窗口大小。

说白了,事件是文档或浏览器中发生的特定交互瞬间!

通过使用JavaScript,你可以监听特定事件的发生,并规定让某些事件发生以对这些事件做出响应(具体代码大家可以通过马海祥博客《JS基础知识:Javascript事件触发列表》的表格来查询)。

二、事件流

事件流就是描述了页面中接受事件的顺序,在浏览器发展的初期,两大浏览器厂商IE和Netscape互掐,出现了一个坑爹的情况,那就是他们对事件流的解释出现了两中截然相反的定义。也就是我们所熟悉的:IE的事件冒泡,Netscape的事件捕获。先来一张图,简要的看下结构:

1、事件冒泡

事件冒泡即事件最开始由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播至最不具体的节点(文档)。拿上面的图来说明,就是当点击text部分时,先由text处的元素接收,然后逐级传播至window,即执行6-7-8-9-10的过程。

2、事件捕获

事件捕获即事件最早由不太具体的节点接收,而最具体的节点最后接收到事件。同理,在上面的模型中,就是点击text部分时,先由window接收,然后逐级传播至text元素,即执行1-2-3-4-5的过程。

具体在代码中怎样表现呢?后面马海祥会给出代码的介绍,大家莫急!

三、Javascript事件处理程序的3种方式

产生了事件,我们就要去处理他,据马海祥了解Javascript事件处理程序主要有3种方式:

1、HTML事件处理程序

即我们直接在HTML代码中添加事件处理程序,如下面这段代码:

<input id="btn1" value="按钮" type="button" οnclick="showmsg();">
  <script>
      function showmsg(){
          alert("HTML添加事件处理");
      }
  </script>

从上面的代码中我们可以看出,事件处理是直接嵌套在元素里头的,这样有一个毛病:就是html代码和js的耦合性太强,如果哪一天我想要改变js中showmsg,那么我不但要再js中修改,我还需要到html中修改,一两处的修改我们能接受,但是当你的代码达到万行级别的时候,修改起来就需要劳民伤财了,所以,这个方式我们并不推荐使用。

2、DOM0级事件处理程序

即为指定对象添加事件处理,看下面的一段代码

<input id="btn2" value="按钮" type="button">
  <script>
    var btn2= document.getElementById("btn2");
      btn2.οnclick=function(){
      alert("DOM0级添加事件处理");
    } 
    btn.οnclick=null;//如果想要删除btn2的点击事件,将其置为null即可
  </script>

从上面的代码中,我们能看出,相对于HTML事件处理程序,DOM0级事件,html代码和js代码的耦合性已经大大降低。但是,聪明的程序员还是不太满足,期望寻找更简便的处理方式,下面马海祥就来说说第三种处理方法。

3、DOM2级事件处理程序

DOM2也是对特定的对象添加事件处理程序(具体可查看马海祥博客的《JavaScript对象属性的基础教程指南》相关介绍),但是主要涉及到两个方法,用于处理指定和删除事件处理程序的操作:addEventListener()和 removeEventListener()。

它们都接收三个参数:要处理的事件名、作为事件处理程序的函数和一个布尔值(是否在捕获阶段处理事件),看下面的一段代码:

<input id="btn3" value="按钮" type="button">
  <script>
     var btn3=document.getElementById("btn3");
     btn3.addEventListener("click",showmsg,false);//这里我们把最后一个值置为false,即不在捕获阶段处理,一般来说冒泡处理在各浏览器中兼容性较好
     function showmsg(){
         alert("DOM2级添加事件处理程序");
     }
     btn3.removeEventListener("click",showmsg,false);//如果想要把这个事件删除,只需要传入同样的参数即可
  </script>

这里我们可以看到,在添加删除事件处理的时候,最后一种方法更直接,也最简便。但是马海祥提醒大家需要注意的是,在删除事件处理的时候,传入的参数一定要跟之前的参数一致,否则删除会失效!

四、事件冒泡和事件捕获的流程与区别

说到这里,马海祥再给大家来一点代码来说明下事件冒泡和事件捕获的流程,同时也让大家能看出二者的区别:

<!doctype html>
  <html lang="en">
  <head>
      <meta charset="UTF-8">
      <title>Document</title>
      <style>
          #p{width:400px;height:200px;border:1px solid black;}
          #c{width:200px;height:100px;border:1px solid red;}
      </style>
  </head>
  <body>
      <div id="p">
          i am www.mahaixiang.cn
          <div id="c">i like www.mahaixiang.cn</div>
      </div>
      <script>
       var p = document.getElementById('p');
         var c = document.getElementById('c');
         c.addEventListener('click', function () {
              alert('子节点捕获')
          }, true);
         c.addEventListener('click', function () {
              alert('子节点冒泡')
         }, false);
         p.addEventListener('click', function () {
               alert('父节点捕获')
           }, true);
         p.addEventListener('click', function () {
             alert('父节点冒泡')
          }, false);
      </script>
  </body>
  </html>

运行上面的代码,点击子元素的时候,我们会发现,执行的先后顺序是:父节点捕获--子节点捕获--子节点冒泡--父节点冒泡。从这个例子中,大家也就明白了,另外,DOM2级事件规定事件包括三个阶段:

1、事件捕获阶段;

2、处于目标阶段;

3、事件冒泡阶段。

首先是捕获,然后处于目标阶段(即来到事件的发出位置),最后才是冒泡,

不科学的是,居然木有DOM1级事件处理程序,大家注意下,别闹出笑话了!

马海祥博客补充:IE事件处理程序也对应有两个方法:attachEvent()添加事件,detachEvent()删除事件,这两个方法接收相同的两个参数:事件处理程序名称与事件处理函数。

这里为什么没有布尔值呢?因为ie8以及更早的版本只支持事件冒泡,所以最后一个参数默认的相当于false来处理!(支持IE事件处理程序的浏览器有IE,opera)

五、事件处理程序的浏览器兼容性

既然不同的浏览器对事件处理程序有这自己不同的支持,那么,我们在开发中,岂不是每次使用事件处理程序时都要对不同的浏览器做一次兼容?这里马海祥封装一个兼容方法,以后在事件处理的时候,直接调用即可,看下面一段代码:

<!doctype html>
  <html lang="en">
  <head>
      <meta charset="UTF-8">
      <title>Document</title>
  </head>
  <body>
  <input id="btn" type="button" value="按钮">
      <script>
      var eventHandler={
          addHandler:function(element,type,func){
              if(element.addEventListener){
                  element.addEventListener(type,func,false);
              }else if(element.detachEvent){
                  element.attachEvent('on'+type,func);
              }else{
                  element['on'+type]=func;
              }
          },
          removerHandler:function(element,type,func){
              if(element.removeEventListener){
                  element.removeEventListener(type,func,false);
              }else if(element.detachEvent){
                  element.detachEvent('on'+type,func);
              }else{
                  element['on'+type]=null;
              }
          }
      }
      function showmsg(){
          alert("hello");
      }
      var btn=document.getElementById("btn");
      eventHandler.addHandler(btn,"click",showmsg);
      //eventHandler.removerHandler(btn,"click",showmsg);//去掉事件处理
      </script>
  </body>
  </html>

上面的代码在ie和其他浏览器中都能正常处理事件,以后如果需要使用兼容性的操作,都可以直接调用这段代码。

马海祥博客点评:

事件对象是用来记录一些事件发生时的相关信息的对象,但事件对象只有事件发生时才会产生,并且只能是事件处理函数内部访问,在所有事件处理函数运行结束后,事件对象就被销毁!

本文为马海祥博客原创文章,如想转载,请注明原文网址摘自于http://www.mahaixiang.cn/js/694.html,注明出处;否则,禁止转载;谢谢配合!

转载于:https://www.cnblogs.com/qingsong/p/5258004.html

JavaScript事件处理程序的3种方式相关推荐

  1. Javascript事件绑定的几种方式

    Javascript事件绑定的几种方式 来源:http://www.cnblogs.com/rainman/archive/2009/02/11/1387955.html 上篇文章讲到了事件绑定的3中 ...

  2. javascript添加HTML事件处理程序的两种方式学习

    以按钮单击事件为例: 可以直接在button元素的onclick属性中直接执行javascript代码:示例代码和结果如下图: 也可以在onclick属性中指定要调用的函数:示例代码和结果如下图: 在 ...

  3. 读《Javascript高级程序设计》中的javascript事件处理程序(事件侦听器)心得

    今天读了<Javascript高级程序设计>中的javascript事件处理程序(事件侦听器)部分的内容,总结一些自己的心得: 事件就是用户或者浏览器自身执行的某种动作.例如click . ...

  4. js中事件绑定的几种方式

    事件处理程序即给元素绑定事件的方式有下列几种:HTML事件处理程序.DOM0级事件处理程序.DOM2级事件处理程序.IE事件处理程序.跨浏览器事件处理程序.其实这些方式就是一个逐步优化和实现跨浏览器的 ...

  5. 为元素绑定多个相同事件 绑定事件的另一种方式 复习 介绍 元素的事件绑定

    为元素绑定多个相同事件 <!DOCTYPE html> <html lang="en"> <head><meta charset=&quo ...

  6. javascript事件处理程序

    javascript 事件处理程序 1.普通事件处理程序 <input type="button" value="click me" οnclick=&q ...

  7. JavaScript定义函数的几种方式

    上节我们介绍了<JavaScript工作体系中不可或缺的函数>,函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块.接下来我们说说js当中定义(声明)函数的几种方式,以及每种方式的 ...

  8. JavaScript定义函数的几种方式 1

    上节我们介绍了<JavaScript工作体系中不可或缺的函数>,函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块.接下来我们说说js当中定义(声明)函数的几种方式,以及每种方式的 ...

  9. JavaScript定义类的几种方式

    1.工厂方式 javaScript中创建自己的类和对象,我们应该是必须掌握的,我们都知道javaScript中对象的属性可以在对象创建后动态定义,比如下面的代码: <script type=&q ...

最新文章

  1. 【Java学习】从一个简单的HelloWorld项目中入门maven
  2. 【Python】利用 pytesseract 识别图片中的数字
  3. 玄元剑仙服务器列表为空,玄元剑仙3月11日维护更新公告
  4. 分布式事务最终一致性-CAP框架轻松搞定
  5. html页面授权码,spring boot 2.0 整合 oauth2 authorization code授权码模式
  6. 用Kubernetes搭建Etcd集群和WebUI
  7. iOS CoreImage之滤镜简单使用
  8. UI设计动效\动画素材模板|分层分步骤学习动效设计
  9. mongo数据库去重
  10. O'Stolz 定理及其应用
  11. 中介分析(二): 多重中介分析
  12. python使用win32com复制word的某一页然后粘贴到新的word页面中
  13. win7家庭版如何升级到专业版和旗舰版
  14. 苹果6访问限制密码4位_苹果ios签名:AppleID为什么开启双重认证那么重要
  15. WIN11自定义版本镜像下载教程
  16. cad打印本计算机未配置,为什么CAD点打印的时候就会警告提示无法使用此绘图仪配置?有什么解决办法?...
  17. ppt转换成pdf格式转换器怎么使用
  18. android 系统中将 键盘的esc键修改为 和back一样的功能
  19. 【论文翻译】nuPlan: A closed-loop ML-based planning benchmark for autonomous vehicles
  20. 【C++ 科学计算】矩阵元素绝对值小于设定值时,元素值变为零

热门文章

  1. system流怎么判断为空_面试时被问到单例模式,怎么回答才能让面试官眼前一亮?...
  2. ubuntu java对比win_Ubuntu PK Vista Java性能大比拼
  3. C语言自底向上分析方法,算法6-12:自底向上的赫夫曼编码 (C语言代码)
  4. java 端口转发_用Java快速实现端口转发
  5. deepdive连接mysql数据库_如何从Error Code获取Message
  6. gitlab clone需要密码_搭建gitlab服务器最详教程
  7. Node.js package.json
  8. TensorFlow tf.keras.layers.Dense
  9. java 接口案例
  10. navicat导出查询结果原理_使用Navicat生成ER关系图并导出