JavaScript事件处理的方式(三种)


Posted in Javascript onApril 26, 2016

最近这段时间因为每天要修改网站,为网站做特效,所以看了很多的js接触事件,自己只会使用一小部分,有时用的时候也比较混乱,现在系统的整理了一下,特此分享到三水点靠木平台供大家参考下!

一、什么是JavaScript事件?

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

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

通过使用JavaScript,你可以监听特定事件的发生,并规定让某些事件发生以对这些事件做出响应。

二、事件流

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

JavaScript事件处理的方式(三种)

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="btn" value="按钮" type="button" onclick="showmsg();">
<script>

 function showmsg(){

 alert("HTML添加事件处理");

 }

</script>

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

2、DOM0级事件处理程序

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

<input id="btn" value="按钮" type="button">
<script>


var btn= document.getElementById("btn");

 btn.onclick=function(){



alert("DOM级添加事件处理");


} 


btn.onclick=null;//如果想要删除btn的点击事件,将其置为null即可

</script>

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

3、DOM2级事件处理程序

DOM2也是对特定的对象添加事件处理程序,但是主要涉及到两个方法,用于处理指定和删除事件处理程序的操作:addEventListener()和 removeEventListener()。它们都接收三个参数:要处理的事件名、作为事件处理程序的函数和一个布尔值(是否在捕获阶段处理事件),看下面的一段代码:

<input id="btn" value="按钮" type="button">
<script>

 var btn=document.getElementById("btn");

 btn.addEventListener("click",showmsg,false);//这里我们把最后一个值置为false,即不在捕获阶段处理,一般来说冒泡处
理在各浏览器中兼容性较好

 function showmsg(){

 alert("DOM级添加事件处理程序");

 }

 btn.removeEventListener("click",showmsg,false);//如果想要把这个事件删除,只需要传入同样的参数即可

</script>

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

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

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

<!doctype html>
<html lang="en">

<head>

 <meta charset="UTF-">

 <title>Document</title>

 <style>

 #p{width:px;height:px;border:px solid black;}

 #c{width:px;height:px;border:px 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级事件处理程序,大家注意下,别闹出笑话了!

五、补充

1. IE事件处理程序也对应有两个方法:attachEvent()添加事件,detachEvent()删除事件,这两个方法接收相同的两个参数:事件处理程序名称与事处理函数。这里为什么没有布尔值呢?因为ie8以及更早的版本只支持事件冒泡,所以最后一个参数默认的相当于false来处理!(支持IE事件处理程序的浏览器有IE,opera)。

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

以上所述是小编给大家介绍的JavaScript事件处理的方式(三种),希望对大家有所帮助!

Javascript 相关文章推荐
JS返回上一页实例代码通过图片和按钮分别实现
Aug 16 Javascript
JavaScript动态创建div属性和样式示例代码
Oct 09 Javascript
使用js判断TextBox控件值改变然后出发事件
Mar 07 Javascript
jQuery 实现评论等级好评差评特效
May 06 Javascript
详解JavaScript中|单竖杠运算符的使用方法
May 23 Javascript
js判断复选框是否选中及选中个数的实现代码
May 30 Javascript
微信支付 JS API支付接口详解
Jul 11 Javascript
利用Js+Css实现折纸动态导航效果实例源码
Jan 25 Javascript
详解在vue-cli项目下简单使用mockjs模拟数据
Oct 19 Javascript
微信小程序实现收货地址左滑删除
Nov 18 Javascript
Vue3.0中的monorepo管理模式的实现
Oct 14 Javascript
解决$store.getters调用不执行的问题
Nov 08 Javascript
学习AngularJs:Directive指令用法(完整版)
Apr 26 #Javascript
jQuery siblings()用法实例详解
Apr 26 #Javascript
JQuery插件Marquee.js实现无缝滚动效果
Apr 26 #Javascript
Angular.js回顾ng-app和ng-model使用技巧
Apr 26 #Javascript
Bootstrap每天必学之工具提示(Tooltip)插件
Apr 26 #Javascript
Bootstrap网格系统详解
Apr 26 #Javascript
Bootstrap每天必学之标签页(Tab)插件
Aug 09 #Javascript
You might like
详解使用php调用微信接口上传永久素材
2017/04/11 PHP
ASP.NET中AJAX 调用实例代码
2012/05/03 Javascript
ECMAScript 创建自己的js类库
2012/11/22 Javascript
js/ajax跨越访问-jsonp的原理和实例(javascript和jquery实现代码)
2012/12/27 Javascript
php跨域调用json的例子
2013/11/13 Javascript
extjs4 treepanel动态改变行高度示例
2013/12/17 Javascript
如何减少浏览器的reflow和repaint
2015/02/26 Javascript
javascript禁止超链接跳转的方法
2016/02/02 Javascript
jQuery实现鼠标选中文字后弹出提示窗口效果【附demo源码】
2016/09/05 Javascript
微信小程序实现运动步数排行功能(可删除)
2018/07/05 Javascript
15分钟上手vue3.0(小结)
2020/05/20 Javascript
Vue清除定时器setInterval优化方案分享
2020/07/21 Javascript
vue实现简单的登录弹出框
2020/10/26 Javascript
Python使用django获取用户IP地址的方法
2015/05/11 Python
Python贪吃蛇游戏编写代码
2020/10/26 Python
Python3实战之爬虫抓取网易云音乐的热门评论
2017/10/09 Python
python+matplotlib绘制饼图散点图实例代码
2018/01/20 Python
python+selenium实现自动化百度搜索关键词
2019/06/03 Python
使用python进行波形及频谱绘制的方法
2019/06/17 Python
PyQt5实现让QScrollArea支持鼠标拖动的操作方法
2019/06/19 Python
简单了解Django ORM常用字段类型及参数配置
2020/01/07 Python
python 给图像添加透明度(alpha通道)
2020/04/09 Python
基于python实现操作redis及消息队列
2020/08/27 Python
HTML5 Canvas玩转酷炫大波浪进度图效果实例(附demo)
2016/12/14 HTML / CSS
特罗佩亚包官方网站:Tropea
2017/01/03 全球购物
Saucony澳大利亚官网:美国跑鞋品牌,运动鞋中的劳斯莱斯
2018/05/05 全球购物
厨房领班竞聘演讲稿
2014/04/23 职场文书
初中班级口号
2014/06/09 职场文书
班级文化建设标语
2014/06/23 职场文书
关于学习的决心书
2015/02/05 职场文书
三潭印月的导游词
2015/02/12 职场文书
初中班长竞选稿
2015/11/20 职场文书
2019年特色火锅店的创业计划书模板
2019/08/28 职场文书
python编写函数注意事项总结
2021/03/29 Python
数据库连接池
2021/04/06 MySQL
Jpa Specification如何实现and和or同时使用查询
2021/11/23 Java/Android