AutoCAD 3DMAX C语言 Pro/E UG JAVA编程 PHP编程 Maya动画 Matlab应用 Android
Photoshop Word Excel flash VB编程 VC编程 Coreldraw SolidWorks A Designer Unity3D
 首页 > JavaScript

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

51自学网 http://www.wanshiok.com
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程序设计有所帮助。


JavaScript,跨浏览器,添加,删除,事件绑定  
上一篇:JS实现转动随机数抽奖的特效代码  下一篇:jquery控制显示服务器生成的图片流