var obj = document.getElementById("obj"); obj.setAttribute("onclick", "javascript:alert('测试');"); 但是IE不支持用 setAttribute 设置某些属性,包括对象属性、集合属性、事件属性,也就是说用 setAttribute 设置 style、onclick、onmouseover 这些属性在 IE 中是行不通的。 IE 支持 attachEvent,object.attachEvent(event,function),例如: 或者写成 obj.attachEvent("onclick", function(){alert("测试");}); 其它浏览器支持 addEventListener,element.addEventListener(type,listener,useCapture, 同样也可写在一起obj.addEventListener("click", function(){alert("测试");}, false); 注意 attachEvent 的事件带 on,如 onclick,而 addEventListener 不带 on,如 click。 上面有两种添加事件的方法,为了同一添加事件的方法,我们不得不再重新写一个通用的添加事件函数: 版本一: html5工作组的版本: 例:obj.onclick = Foo; 这种绑定事件的方式,兼容主流浏览器,但如果一个元素上添加多次同一事件呢? 如果这样写,那么只有最后绑定的事件,这里是method3会被执行,此时应该用方法二的方法进行事件的绑定 区别IE6、IE7、IE8之间的方法:
JS动态添加事件的方法有很多,我们可以使用setAttribute、attachEvent 和 addEventListener等等,感兴趣的朋友可以参考下
Javascript 是一种由Netscape的LiveScript发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
来源: