JavaScript的事件机制详解
作者:熊仔其人 发布时间:2024-05-03 15:58:45
事件是将JavaScript脚本与网页联系在一起的主要方式,是JavaScript中最重要的主题之一,深入理解事件的工作机制以及它们对性能的影响至关重要。本文将详细探讨JavaScript的事件机制,并对比分析了浏览器之间的不同,具体内容包括事件流、事件处理程序绑定方式、事件对象等。
如何理解事件?
JavaScript与HTML之间的交互就是通过事件实现的。
事件:用户或浏览器自身执行的某种动作,换言之,文档或浏览器发生的一些特定的交互瞬间。
事件处理程序:又称事件 * ,事件发生时执行的代码段。
事件流:事件流描述的是从页面中接收事件的顺序。
两种基本事件模型
事件冒泡:事件按照从最特定的事件目标到最不特定的事件目标(document对象)的顺序触发。
事件捕获:事件从最不精确的对象(document 对象)开始触发,然后到最精确。
IE9、Safari、Chrome、Opera、Firefox都是从window对象开始捕获,冒泡到window对象
DOM事件流
同时支持 两种基本事件模型,规定事件流包括三个阶段:事件捕获阶段、处于目标阶段、事件冒泡阶段。
DOM事件处理程序绑定时,程序员可以自己选择绑定事件时采用事件捕获还是事件冒泡。
IE事件流
IE只支持事件冒泡,不支持事件捕获。
事件处理程序绑定方式
DOM事件处理程序
DOM事件处理程序属性名为“on”+事件名,程序作用域为元素的作用域,this指向元素本身。
方法一:将函数值赋给一个事件处理程序属性。如下:
var btn= document.getElementById("myBtn");
btn.onclick = function{ //具体代码段 }
注意:此种方法只能添加一个事件处理程序
方法二:通过addEventListener方法。如下:
addEventListener("事件名",事件处理程序,ture/false:在事件捕获/冒泡阶段调用模型)
对应的事件处理程序移除方法:removeEventListener,参数必须相同。
注意:此种方法,以匿名函数添加的事件处理程序无法被移除
此方法可以添加多个事件处理程序
IE事件处理程序
IE+Oprea浏览器
程序作用域为全局作用域,this指向window对象
添加方法:attachEvent("on+事件名",事件处理程序)
移除方法:detachEvent("on+事件名",事件处理程序)
事件对象
在触发某个事件时,会产生一个相应的事件对象,这个对象包含所有与事件相关的信息。如:导致事件的元素、事件的类型等
DOM中的事件对象
对象名:event
常用属性:
type:被触发事件的类型
target:事件的目标
常用方法:
event.preventDefault:取消事件默认行为(前提:cancelable属性值为true)
event.stopPropagation:取消事件的进一步冒泡或捕获
IE中的事件对象
对象名:window.event
常用属性:
type:被触发事件的类型
scrElement:事件的目标
常用方法:
event.cancelBubble(true/false):true->取消事件默认行为
event.returnValue(true/false):false->取消事件的进一步冒泡或捕获
综合以上所述,整理代码写可跨浏览器的事件处理程序(构造EventUtil对象,为其添加可兼容各浏览器的事件处理方法),如下:
/*可跨浏览器的事件处理程序
构造EventUtil对象,为其添加可兼容各浏览器的事件处理方法
*/
var EventUtil = {
/*添加事件处理程序*/
addHandler: function (element, type, handler) {
if (element.addEventListener) {
addEventListener(type, handler, false);
} else if (element.attachEvent) {
attachEvent("on" + type, handler);
} else {
element["on" + type] = handler;
}
},
/*移除事件处理程序*/
removeHandler: function (element, type, handler) {
if (element.removeEventListener) {
removeEventListener(type, handler, false);
} else if (element.detachEvent) {
detachEvent("on" + type, handler);
} else {
element["on" + type] = null;
}
},
/*获得事件对象*/
getEvent: function (event) {
return event ? event : window.event;
},
/*获得事件的目标*/
getTarget: function (event) {
return event.target || event.scrElement;
},
/*取消事件的默认行为*/
preventDefault: function (event) {
if (event.preventDefault) {
event.preventDefault;
} else {
event.returValue = false;
}
},
/*阻止事件进一步冒泡*/
stopPropagation: function (event) {
if (event.stopPropagation) {
event.stopPropagation;
} else {
event.cancelBubble = true;
}
}
};
来源:http://www.cnblogs.com/xiongzaiqiren/p/6289499.html


猜你喜欢
- 前几篇都是手动录入或随机函数产生的数据。实际有许多类型的文件,以及许多方法,用它们从文件中提取数据来图形化。比如之前python基础(12)
- 我们很少会一次性从数据库中取出所有的数据;通常都只针对一部分数据进行操作。 在Django API中,我们可以使用`` filter()``
- 本文实例为大家分享了python实现简易五子棋游戏的具体代码,供大家参考,具体内容如下运行效果: 完整代码+注释: fi
- 最近关于浏览器的最重要的事情就是IE的极光0day漏洞了,这个漏洞导致包括Google在内的多家美国公司受到黑客的攻击,当然也有很多网站被黑
- 删除重复记录,将TABLE_NAME中的不重复记录保存到#TABLE_NAME中select distinct&nbs
- 一·算术运算符在python中,算术运算符与数学中的算术运算极为类似,只是有些运算符号有所差别。算术运算符的算术计算一
- 一、概述公司新购了一批PC,准备把几个性能较优的PC升级为数据库服务器,替换老旧的机器。公司有套POS终端软件,后台数据存储是 MySQL
- 本文主要给大家介绍了关于CentOS 6.5 安装Python 3.5.2并与Python2并存的相关内容,分享出来供大家参考学习,下面来看
- 读写文件首先看一个例子:f = open('thefile.txt','w') #以写方式打开,
- 有时候,我们需要检测一个元素是否已经存在列表中,并且不区分大小写,如:列表已有元素Mary,那我们想认为MARY也已经被占用。这个例子在实际
- Python编程语言的优点非常多,它的编程特色主要体现在可扩充性方面。那么,在接下来的这篇文章中,我们将会为大家详细介绍一下有关Python
- 1. getattr()函数是Python自省的核心函数,具体使用大体如下:class A: def __init__(self): sel
- 前言在Python的世界里,将一个对象以json格式进行序列化或反序列化一直是一个问题。Python标准库里面提供了json序列化的工具,我
- 前言;Python bytes 类型用来表示一个字节串。“字节串“不是编程术语,是我自己&l
- OpenCV imread读取图片失败问题使用一下代码读取一张图片失败(不管是绝对路径还是相对路径,都失败),工程运行都没问题,就是图片读取
- 目录1. np.multiply()函数1.1数组场景1.2 矩阵场景2. np.dot()函数2.1 数组场景2.2 矩阵场景3. 星号(
- 本文实例讲述了Django实现简单分页功能的方法。分享给大家供大家参考,具体如下:使用django的第三方模块django-pure-pag
- 本文实例讲述了PHP+Ajax简单get验证操作。分享给大家供大家参考,具体如下:1、显示页面代码index.html<!DOCTYP
- 首先centos7 已经不支持mysql,因为收费了你懂得,所以内部集成了mariadb,而安装mysql的话会和mariadb的文件冲突,
- 首先官网上的树形控件教程地址为Element - The world's most popular Vue UI framework