javascript代码实例教程-JS动态添加事件

发布时间:2019-02-25 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了javascript代码实例教程-JS动态添加事件脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。 方法一、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),例如:

[javascript] 

obj.attachEvent("onclick", Foo);  

function Foo()  

{  

    alert("测试");  

}  

或者写成 obj.attachEvent("onclick", function(){alert("测试");});

其它浏览器支持 addEventListener,element.addEventListener(tyPE,listener,useCapture,

[javascript] 

obj.addEventListener("click", Foo, false);  

function Foo()  

{  

    alert("测试");  

}  

同样也可写在一起obj.addEventListener("click", function(){alert("测试");}, false);

注意 attachEvent 的事件带 on,如 onclick,而 addEventListener 不带 on,如 click。

[javascript] 

考虑兼容性:  

if (window.attachEvent)//兼容IE  

{  

    //IE 的事件代码  

}  

else  

{  

    //其它浏览器的事件代码  

}  

上面有两种添加事件的方法,为了同一添加事件的方法,我们不得不再重新写一个通用的添加事件函数:

 

版本一:

 

 

[javascript]  

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工作组的版本:

[javascript] 

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;

如果这样写,那么只有最后绑定的事件,这里是method3会被执行,此时应该用方法二的方法进行事件的绑定

 

 

 

区别IE6、IE7、IE8之间的方法:

 

[javascript]  

var isIE=!!window.ActiveXObject;  

var isIE6=isIE&&!window.XMLHttPRequest;  

var isIE8=isIE&amp;&!!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代码实例教程-JS动态添加事件全部内容,希望文章能够帮你解决javascript代码实例教程-JS动态添加事件所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。