多种方法实现JS动态添加事件
多种方法实现JS动态添加事件
发布时间:2016-12-30 来源:查字典编辑
摘要:方法一、setAttributevarobj=document.getElementById("obj");obj.setAttribute...

方法一、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", 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;

这种绑定事件的方式,兼容主流浏览器,但如果一个元素上添加多次同一事件呢?

复制代码 代码如下:

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″);

}

}

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类