在触发DOM上的某个事件时,会产生一个事件对象event,这个对象中包含这所有与事件有关的信息。包括导致事件的元素、事件的类型和事件的相关信息。例如鼠标操作的事件中,会包含鼠标的位置信息。而键盘触发的事件会包含与按下的键有关信息。所有浏览器都支持event对象,但支持方式不同。
- DOM中的事件对象
兼容dom的浏览会将一个event对象传递到事件处理程序中。
1 var aa=document.getElementById("aa");
2 aa.onclick=function(event){
3 console.log(event.type);
4 }
5 aa.addEventListener("click",function(event){
6 console.log(event.type);
7 },false);
上面的代码,通过两种方式指定事件处理程序,但是他们可以获得event对象。event.type都是输出click。
属性/方法 | 类型 | 读/写 | 说明 |
bubbles | Boolean | 只读 | 事件是否冒泡 |
cancelable | Boolean | 只读 | 是否可以取消事件的默认行为 |
currentTarget | Element | 只读 | 事件处理程序正在处理的那个元素 |
defaultPrevented | Boolean | 只读 | 是否已经调用了preventDefault方法 |
detail | Integer | 只读 | 事件的细节信息 |
eventPhase | Integer | 只读 | 调用事件处理程序的阶段 |
preventDefault() | Function | 只读 | 取消事件的默认行为 |
stopImmediatePropagation() | Function | 只读 | 取消事件的进一步捕获或者冒泡 |
stopPropagation() | Function | 只读 | 取消事件的进一步冒泡或者捕获 |
target | Element | 只读 | 事件的目标 |
trusted | Boolean | 只读 | 为true表示事件是浏览器生成,false表示JavaScript添加 |
type | String | 只读 | 被触发事件的类型 |
view | AbstarctView | 只读 | 与事件关联的抽象视图 |
上面的表格列出了event的属性以及方法,在事件处理程序内部,对象this始终等于currentTarget的值,而target则包含事件的实际目标。如果直接将事件处理程序指定给了目标元素,则this、target和currentTaget包含相同的值。
1 aa.addEventListener("click",function(event){
2 console.log(event.target==this);//true
3 console.log(event.currentTarget==this);//true
4 },false);
上面的代码中说明currentTarget、target和this的值是相同的。通过下面的代码,我们可以看出this就是指向元素本身。
1 aa.addEventListener("click",function(event){
2 //console.log(event.target==this);//true
3 //console.log(event.currentTarget==this);//true
4 console.log(this==document.getElementById("aa"));//true
5 console.log(event.currentTarget==document.getElementById("aa"));//true
6 },false);
要阻止特定事件的默认行为,可以使用preventDefault方法。例如a标签,在点击的时候,会跳转到指定的url链接,如果想阻止该行为的发生,可以调用preventDefault方法。
1 document.getElementById("hh").onclick=function(event){
2 event.preventDefault();
3 }
上面的代码将会阻止跳转事件的发生。只有cancelable为true,才能调用该方法。通过调用stopPropagation方法能够阻止事件的冒泡。
1 document.getElementById("hh").onclick=function(event){
2 console.log(event.eventPhase);//2
3 event.preventDefault();
4 }
5 document.body.onclick=function(event){
6 console.log(event.eventPhase);//3
7 }
8 document.body.addEventListener("click",function(event){
9 console.log(event.eventPhase);//1
10 },true);
上面的代码中输出是1,2,3。由此可见,document.body.addEventListener最先执行,它发生在事件的冒泡阶段,document.getElementById("hh")第二个执行,发生在事件的处理程序目标阶段。document.body.onclick发生在事件的冒泡阶段。
- IE中的事件对象
在IE中方式event对象可以通过多种方式,取决于指定事件处理程序的方法。
1 aa.onclick=function(){
2 var event=window.event;
3 console.log(event.type);
4 }
上面的代码,我们通过window.event获取了event对象,并且可以取得它的属性和方法。但是如果通过attachEvent添加事件,则事件处理程序会传递一个event对象。
IE的event对象同样包含创建它的相关属性和方法,与DOM事件一样,也会因为事件类型的不同而不同。
属性/方法 | 类型 | 读写 | 说明 |
cancelBubble | Boolean | 读/写 | 默认false,设置为true,取消事件冒泡 |
returnValue | Boolean | 读/写 | 默认为true,设置为false,取消事件的默认行为 |
srcElement | Element | 只读 | 事件的目标,与target相同 |
因为事件处理程序的指定方式不同,故它的作用域也不相同。最好不用this,可以使用srcElement来获取元素。
如前所述,returnValue属性相当于DOM中的preventDefault方法,它们的作用都是取消给定事件的默认行为。只要将returnValue设置为false,就会阻止默认事件的发生。
1 EventUtil.addEvent(document.getElementById("hh"),"click",function(event){
2 event.returnValue=false;
3 });
- 跨浏览器的事件对象
虽然DOM与IE的event对象不同,但是可以通过js库,来解决浏览器的兼容性。
1 var EventUtil={
2 /**
3 * 添加事件
4 * @param {Object} element:元素本身
5 * @param {Object} type:事件名称
6 * @param {Object} fn:事件处理程序
7 */
8 addEvent:function(element,type,fn){
9 if(element.addEventListener){
10 element.addEventListener(type,fn,false);
11 }
12 else if(element.attachEvent){
13 element.attachEvent("on"+type,fn);
14 }
15 else{
16 element["on"+type]=fn;
17 }
18 },
19 /**
20 * 移除事件
21 * @param {Object} element:元素本身
22 * @param {Object} type:事件名称
23 * @param {Object} fn:事件处理程序
24 */
25 removeEvent:function(element,type,fn){
26 if(element.removeEventListener){
27 element.removeEventListener(type,fn,false);
28 }
29 else if(element.detachEvent){
30 element.detachEvent("on"+type,fn);
31 }
32 else{
33 element["on"+type]=null;
34 }
35 },
36 /**
37 * 获取事件对象
38 * @param {Object} event
39 */
40 getEvent:function(event){
41 return event||window.event;
42 },
43 /**
44 * 获取事件处理程序作用的目标元素
45 * @param {Object} event
46 */
47 getTarget:function(event){
48 return event.currentTarget||event.srcElement;
49 },
50 /**
51 * 取消默认行为
52 * @param {Object} event
53 */
54 preventDefault:function(event){
55 if(event.preventDefault){
56 event.preventDefault();
57 }
58 else{
59 event.returnValue=false;
60 }
61 },
62 /**
63 * 取消冒泡
64 * @param {Object} event
65 */
66 stopPropagation:function(event){
67 if(event.stopPropagation){
68 event.stopPropagation();
69 }
70 else{
71 event.cancelBubble=true;
72 }
73 }
74 };
上面的代码封装了事件处理中需要的方法,包括添加事件、移除事件、获取事件对象、获取事件的目标元素、阻止默认行为和阻止冒泡。