本文介绍下,在javascript编程中,动态添加事件的几种方法,包括 使用setAttribute、attachEvent 和 addEventListener等,供大家学习参考。
本节内容:
JS动态添加事件
可以使用setAttribute、attachEvent 和 addEventListener等。
方法1、setAttribute 
 
复制代码 代码示例:
var obj = document.getElementById("obj"); 
obj.setAttribute("onclick", "
javascript:alert('测试');"); 
 
但是IE不支持用 setAttribute 设置某些属性,包括对象属性、集合属性、事件属性,也就是说用 setAttribute 设置 style、onclick、onmouseover 这些属性在 IE 中是行不通的。
方法2、用 attachEvent 和 addEventListener 
IE 支持 attachEvent,object.attachEvent(event,function),例如: 
 
复制代码 代码示例:
obj.attachEvent("onclick", Foo); 
function Foo() 
{ 
alert("测试"); 
}
或写成
复制代码 代码示例:
obj.attachEvent("onclick", function(){alert("测试");}); 
 
其它浏览器支持 addEventListener,element.addEventListener(type,listener,useCapture, 
 
复制代码 代码示例:
obj.addEventListener("click", Foo, false); 
function Foo() 
{ 
alert("测试"); 
}
同样也可写在一起
复制代码 代码示例:
obj.addEventListener("click", function(){alert("测试");}, false); 
 
注意 attachEvent 的事件带 on,如 onclick,而 addEventListener 不带 on,如 click。
考虑兼容性: 
 
复制代码 代码示例:
if (window.attachEvent)//兼容IE 
{ 
//IE 的事件代码 
} 
else 
{ 
//其它浏览器的事件代码 
}
上面有两种添加事件的方法,为了同一添加事件的方法,我们不得不再重新写一个通用的添加事件函数:
版本一: 
 
复制代码 代码示例:
function addEvent(elm, evType, fn, useCapture) { 
if (elm.addEventListener) { 
elm.addEventListener(evType, fn, useCapture);//DOM2.0 
return true; 
} 
else if (elm.attachEvent) { 
var r = elm.attachEvent(‘on‘ + evType, fn);//IE5+ 
return r; 
} 
else { 
elm['on' + evType] = fn;//DOM 0 
} 
}
HTML5工作组的版本: 
 
复制代码 代码示例:
var addEvent=(function(){ 
if(document.addEventListener){ 
return function(el,type,fn){ 
if(el.length){ 
for(var i=0;i<el.length;i++){ 
addEvent(el[i],type,fn); 
} 
}else{ 
el.addEventListener(type,fn,false); 
} 
}; 
}else{ 
return function(el,type,fn){ 
if(el.length){ 
for(var i=0;i<el.length;i++){ 
addEvent(el[i],type,fn); 
} 
}else{ 
el.attachEvent(‘on‘+type,function(){ 
return fn.call(el,window.event); 
}); 
} 
}; 
} 
})();
方法3、事件 = 函数 
例:obj.onclick = Foo; 
这种绑定事件的方式,兼容主流浏览器,但如果一个元素上添加多次同一事件呢? 
 
obj.onclick=method1; 
obj.onclick=method2; 
obj.onclick=method3;
如果这样写,那么只有最后绑定的事件,这里是method3会被执行,此时应该用方法二的方法进行事件的绑定。
区别IE6、IE7、IE8之间的方法: 
 
复制代码 代码示例:
var isIE=!!window.ActiveXObject; 
var isIE6=isIE&&!window.XMLHttpRequest; 
var isIE8=isIE&&!!document.documentMode; 
var isIE7=isIE&&!isIE6&&!isIE8; 
if (isIE){ 
  if (isIE6){ 
    alert(”ie6″); 
  }else if (isIE8){ 
    alert(”ie8″); 
  }else if (isIE7){ 
    alert(”ie7″); 
  } 
} 
 
您可能感兴趣的文章:
js动态添加事件且可传参数的代码分享
javascript事件之卸载(unload)事件
javascript事件之滚动(scroll)事件
javascript事件之调整大小(resize)事件
javascript 卸载前beforeunload事件
js中event鼠标事件的例子
javascript event 事件的详细介绍
JavaScript事件处理器event参数详解
Js鼠标事件大全(最新,最全的版本)
动态添加mouseover和mouseout事件的js代码
动态添加页面body OnLoad事件的简单js代码
javascript动态添加onload、onresize、onscroll事件的方法
js动态添加onload、onresize、onscroll事件的另类方法
js动态添加页面的BODY OnLoad事件