当前位置:首页 > 日记 > 正文

JavaScript的事件机制详解

JavaScript的事件机制详解

事件是将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;    }  }};

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!

相关文章

thinkPHP5.0框架简单配置作用域的

thinkPHP5.0框架简单配置作用域的

作用域,框架,配置,方法,简单,本文实例讲述了thinkPHP5.0框架简单配置作用域的方法。分享给大家供大家参考,具体如下:配置参数支持作用域的概念,默认情况下,所有参数都在同一个系统默认作用域下面。如果你的配置参数需要用于不同的项目或者相互…

Jquery根据浏览器窗口改变调整大小

Jquery根据浏览器窗口改变调整大小

浏览器,方法,调整,大小,窗口,如下所示:当浏览器窗口发生该表示,会触发resize函数// 浏览器大小发生变化时,给id为main-container的容器设置最小高度<script type="text/javascript"> $(function(){ $(window).resize(function(){ $…

excel2013如何设置纵横页面布局

excel2013如何设置纵横页面布局

页面布局,方法,设置,如何设置,电脑软件,  通常在Excel2013中记录数据,都是采用的纵排排列,就是以列的形式呈现出来,但是有时候用种方式不适合怎么办?下面小编就教你怎么设置excel2013的纵横布局,希望看完本教程的朋友都能学会并运用起来。exc…

word2013怎么插入窗口域word2013插

word2013怎么插入窗口域word2013插

步骤,方法,窗口,电脑软件,strong,  我们在使用word的时候,相信很多人都不知道窗体域这个功能,那么今天小编就来告诉你怎么插入这个功能吧。word2013插入窗口域的步骤第一步,点击&ldquo;文件&rdquo;并选择&ldquo;选项&rdquo;word2013插入窗口…

WPS备份管理怎么备份以便恢复未保

WPS备份管理怎么备份以便恢复未保

备份,恢复,文件,文件备份,电脑软件,  WPS加入了自动备份功能,一旦断电或异常关机等意外不可控情况时便可还原没有来及保存的文件,以便恢复之前的文件或异常未保存的文件。以下是小编为您带来的关于WPS备份管理备份以便恢复未保存的文件,希望…

使用JavaScript实现链表的数据结构

使用JavaScript实现链表的数据结构

链表,数据结构,代码,电脑软件,JavaScript,链表(Linked list)是一种常见的基础数据结构,是一种线性表,但是并不会按线性的顺序存储数据,而是在每一个节点里存到下一个节点的指针(Pointer) — 维基百科上面是维基百科对 链表 的解读。下面我们用…

老生常谈计算机中的编码问题 | 必

老生常谈计算机中的编码问题 | 必

编码问题,计算,老生常谈,必看,机中,计算机中的编码问题因为计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理。最早的计算机在设计时采用8个比特(bit)作为一个字节(byte),所以,一个字节能表示的最大的整数就是255(二进制1111111…

通过V8源码看一个关于JS数组排序的

通过V8源码看一个关于JS数组排序的

数组排序,诡异,源码,电脑软件,JS,前言前几天一个朋友在微信里面问我一个关于 JS 数组排序的问题。通过该问题发现了一些之前没发现的内容,下面话不多少了,来一起看看详细的介绍吧。原始数组如下:var data = [ {value: 4}, {value: 2}, {valu…

Photoshop 7.0新增了哪些功能?

Photoshop 7.0新增了哪些功能?

功能,新增了,电脑软件,Photoshop,Photoshop 7.0 上市好久了 ,当时它也是现在的CC 版本一样 独一无二的, 想知道当年PS&ldquo;进化&rdquo;的过程的同学跟我来吧!介绍你们当时新增的功能。软件名称:Adobe PhotoShop7.0 简体中文版软件大小:154MB更…

Excel中表格工作表保护密码撤销的

Excel中表格工作表保护密码撤销的

密码,操作方法,表格,工作,操作步骤,  在做excel表格时我们有时候会给自己的工作表加密,一旦忘记密码就会很麻烦,如何绕过密码,直接撤销保护。今天,小编就教大家在Excel中表格工作表保护密码撤销的操作方法。Excel中表格工作表保护密码撤销的…

jquery实现回车键触发事件 | 实例

jquery实现回车键触发事件 | 实例

回车键,事件,实例,电脑软件,jquery,键盘事件有3:keydown,keypress,keyup,分别是按下,按着没上抬,上抬键盘 。正确代码为:$(document).keyup(function(event){ if(event.keyCode ==13){ $("#submit").trigger("click"); }});推荐:keyup,防止笔记…

浅谈JavaScript find 方法不支持IE

浅谈JavaScript find 方法不支持IE

方法,不支持,浅谈,电脑软件,find,最近在前端开发中,遇到一个JavaScript 的问题。<script type="text/javascript"> var arrayList = new Array(); arrayList.push(1); arrayList.push(2); arrayList.push(3); arrayList.push(4); a…