JavaScript高级程序设计 阅读笔记(十七) js事件
2024-05-06 14:21:21
供稿:网友
一、事件流
IE中是冒泡型事件,即从最特定的事件目标到最不特定的事件目标。
Netscape Navigator使用的是捕获型事件,这个跟IE中采用的冒泡型事件相反。
DOM事件流同时支持两种事件模型,但捕获型事件先发生。
二、事件处理函数/监听函数
事件是用户或浏览器自身进行的特定行为。这些事件都有自己的名字,如click、load、mouseover等。
事件处理函数有两种分配方式:在JavaScript中或者在HTML中。
如果在JavaScript中分配事件处理函数,则首先要获得要处理的对象的引用,然后将函数赋值给对应的事件处理函数属性,像这样(事件处理函数名称必须小写):
代码如下:
var oDiv=document.getElementById("div1");
oDiv.onclick=function(){
alert("I was clicked");
}
如果在HTML中分配事件处理函数,则只要在HTML标签中添加事件处理函数的特征,并在其中包含合适的脚本作为特性值就可以了,如下:
代码如下:
<div onclick="alert('I was clicked')"></div>
为了给每个可用事件分配多个事件处理函数,IE和DOM各提供了自己的方法。
IE中每个元素和window对象都有两个方法:attachEvent()和detachEvent(),顾名思义,前者用来给一个事件附加事件处理函数,后者用来将事件处理函数分离出来。每个方法都有两个参数:要分配的事件处理函数名字及一个函数。如:
代码如下:
var fnClick=function(){
alert("Clicked");
}
var fnClick2=function(){
alert("Click2");
}
var oDiv=document.getElementById("div");
oDiv.attachEvent("onclick",fnClick);
oDiv.attachEvent("onclick",fnClick2)
oDiv.detachEvent("onclick",fnClick);
oDiv.detachEvent("onclick",fnClick2);
DOM中采用了addEventListener()和removeEventListener()来分配和移除事件处理函数。与IE不同的是这些方法有三个参数,第三个参数标识是用于冒泡阶段还是捕获阶段。用于捕获阶段为true,用于冒泡阶段则为false。移除时第三个参数要跟添加时保持一致。如:
代码如下:
var fnClick=function(){
alert("Clicked");
}
var fnClick2=function(){
alert("Click2");
}
var oDiv=document.getElementById("div");
oDiv.addEventListener("onclick",fnClick,false);
oDiv.addEventListener("onclick",fnClick2,false)
oDiv.removeEventListener("onclick",fnClick,false);
oDiv.removeEventListener("onclick",fnClick2,false);
三、事件对象
事件对象一般包含的信息是:引起事件的对象,事件发生时鼠标的信息,事件发生时键盘的信息。
定位
IE中事件对象是window对象的一个属性event。事件处理函数必须这样访问事件对象:
代码如下:
oDiv.onclick = function(){
var oEvent=window.event;