您好,欢迎访问一九零五行业门户网

JavaScript实现跨浏览器的添加及删除事件绑定函数实例_javascript技巧

本文实例讲述了javascript实现跨浏览器的添加及删除事件绑定函数。分享给大家供大家参考。具体如下:
ie 的事件绑定函数是 attachevent;而 firefox, safari 是 addeventlistener;opera 则两种都支持。使用jquery就可以使用简单的bind(),或者$().click()之类的函数解决,而如果不使用javascript框架的时候,大家可是使用下面的封装bind()函数。
添加事件绑定 bind()
/************************************* 添加事件绑定* @param obj : 要绑定事件的元素* @param type : 事件名称。不加 on. 如 : click 而不是 onclick.* @param fn : 事件处理函数************************************/function bind( obj, type, fn ){ if( obj.attachevent){ obj['e'+type+fn]= fn; obj[type+fn]=function(){ obj['e'+type+fn]( window.event); } obj.attachevent('on'+type, obj[type+fn]); }else obj.addeventlistener( type, fn,false);}
例如给document添加一个点击事件:
var fn=function(){ alert(hello, world!!);};bind(document,click, fn);
删除事件绑定 unbind()
unbind()对于上面的bind()函数
/************************************* 删除事件绑定* @param obj : 要删除事件的元素* @param type : 事件名称。不加 on. 如 : click 而不是 onclick* @param fn : 事件处理函数************************************/function unbind( obj, type, fn ){ if( obj.detachevent){ obj.detachevent('on'+type, obj[type+fn]); obj[type+fn]=null; }else obj.removeeventlistener( type, fn,false);}
例如删除第一个绑定的document点击事件:
复制代码 代码如下:
unbind(document,click,fn);
希望本文所述对大家的javascript程序设计有所帮助。
其它类似信息

推荐信息