JS动态添加事件
2013-11-01 01:02
274 查看
方法一、setAttribute
var obj = document.getElementById("obj");
obj.setAttribute("onclick", "javascript:alert('测试');");
但是IE不支持用
setAttribute 设置某些属性,包括对象属性、集合属性、事件属性,也就是说用 setAttribute 设置 style、onclick、onmouseover 这些属性在 IE 中是行不通的。
方法二、用 attachEvent 和 addEventListener
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之间的方法:
var obj = document.getElementById("obj");
obj.setAttribute("onclick", "javascript:alert('测试');");
但是IE不支持用
setAttribute 设置某些属性,包括对象属性、集合属性、事件属性,也就是说用 setAttribute 设置 style、onclick、onmouseover 这些属性在 IE 中是行不通的。
方法二、用 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); }); } }; } })();
方法三、事件 = 函数
例:obj.onclick = Foo;
这种绑定事件的方式,兼容主流浏览器,但如果一个元素上添加多次同一事件呢?
1 | obj.onclick=method1; |
2 | obj.onclick=method2; |
3 | obj.onclick=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″); } }
相关文章推荐
- jquery结合js实现动态添加内容,并给动态添加的内容添加事件
- js 修改svg样式、动态加入DOM元素、添加事件响应函数
- JS实现为动态创建的元素添加事件操作示例
- 【JavaScript】JS动态给对象添加事件
- JS----动态添加元素绑定事件
- js 动态添加事件
- js动态添加元素为何 点击事件无效
- js 动态给元素添加、移除事件
- JS动态生成表单,并添加行双击事件
- JS实现动态绑定单击事件给节点添加样式
- jquery动态添加元素后, 该元素事件失效,可尝试原生 js写法解决
- js动态添加事件的方法
- 给用js动态创建的标签添加事件
- JS实现动态添加DOM节点和事件的方法示例
- js 动态添加 事件
- 动态添加事件及区分IE和其他浏览器的JS脚本
- 使用js动态添加点击事件时,click与onclick的区别
- 文字添加响应事件,js动态加载CSS, js弹出DIV