JS事件添加和移出的兼容写法示例


Posted in Javascript onJune 20, 2016

本文实例讲述了JS事件添加和移出的兼容写法。分享给大家供大家参考,具体如下:

var EventUtil = {
  addHandler : function (element , type, handler {
     if ( element.addEventListener){
        element.addEventListener(type, handler, false);
      }else if ( element.attachEvent) {
        element.attachEvent("on"+type,handler);
      }else {
         element["on" + type] = handler;
      }
    },
  getEvent : function (event){
      return event ? event : window.event;
     },
   preventDefault : function(event){
      if(event.preventDefault){
         event.preventDefault();
      }else{
         event.returnValue = false;
      }
   },
  removeHandsler : function (element , type , handler){
     if(element.removeEventListener){
         element.removeEventListener(type , handler , false);
     }else if(element.detachEvent){
         element.detachEvent("on" + type , handler);
     }else{
         element["on" + type] = handler;
     }
    }
   stopPropagation : function(event){
      if(event.stopPropagation){
         event.stopPropagation();
      }else {
          event.cancelBubble = true;
      }
    },
   getRelatedTarget : function(event){
      if(event.relatedTarget){
          return event.relatedTarget;
      }else if (event.toElement){
          return event.toElement;
      }else if(event.fromElement){
          return event.fromElement;
      }esle {
          return null;
       }
    },
    getButton : function (event){
       if(document.implementation.hasFeature("MouseEvents" , "2.0")){
          return event.button;
       }else{
           switch(event.button){
             case 0:
             case 1:
             case 3:
             case 5:
             case 7:
               return 0;
             case 2:
             case 6:
               return 2;
             case 4:
               return 1;
            }
        }
     }
} ;

其中,addHandler 和 removeHandsler 个方法首先都会检测传入的元素中是否存在DOM2级方法.如果存在DOM2级方法,则使用该方法:传入事件类型,事件处理程序函数和第三个参数fasle(表示冒泡阶段). 如果存在的是IE的方法,则采取第二种方案.注意此时的事件类型必须加上"on"前缀.最后一种可能就是使用DOM0级方法(在现代浏览器中,应该不会执行这里的代码). 此时,我们使用的是方括号语法来将属性名指定为事件处理程序,或者将属性设置为null.

可以像下面这样使用EventUtil对象:

var btn = document.getElementById("myBtn");
var handler = function(){
  alert("Clicked");
};
EventUtil.addHandler(btn , "click", handler);
//略去其他代码
EventUtil.removeHandler(btn, "click", handler);

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
使用jquery实现简单的ajax
Jul 08 Javascript
使用js Math.random()函数生成n到m间的随机数字
Oct 09 Javascript
javascript封装简单实现方法
Aug 11 Javascript
JS实现获取来自百度,Google,soso,sogou关键词的方法
Dec 21 Javascript
AngularJS中update两次出现$promise属性无法识别的解决方法
Jan 05 Javascript
Ionic + Angular.js实现图片轮播的方法示例
May 21 Javascript
Angular2 之 路由与导航详细介绍
May 26 Javascript
vue2.0 elementUI制作面包屑导航栏
Feb 22 Javascript
Vue插值、表达式、分隔符、指令知识小结
Oct 12 Javascript
使用vue重构资讯页面的实例代码解析
Nov 26 Javascript
基于PHP pthreads实现多线程代码实例
Jun 24 Javascript
antd日期选择器禁止选择当天之前的时间操作
Oct 29 Javascript
Javascript操作表单实例讲解(下)
Jun 20 #Javascript
jQuery获取多种input值的简单实现方法
Jun 20 #Javascript
jQuery图片左右滚动代码 有左右按钮实例
Jun 20 #Javascript
JavaScript操作表单实例讲解(上)
Jun 20 #Javascript
jquery 获取select数组与name数组长度的实现代码
Jun 20 #Javascript
JavaScript提升性能的常用技巧总结【经典】
Jun 20 #Javascript
使用jQuery给input标签设置默认值
Jun 20 #Javascript
You might like
PHP Switch 语句之学习笔记
2013/09/21 PHP
discuz免激活同步登入代码修改方法(discuz同步登录)
2013/12/24 PHP
php使用指定编码导出mysql数据到csv文件的方法
2015/03/31 PHP
PHP实现长文章分页实例代码(附源码)
2016/02/03 PHP
php 遍历目录,生成目录下每个文件的md5值并写入到结果文件中
2016/12/12 PHP
javascript 一些用法小结
2009/09/11 Javascript
百度留言本js 大家可以参考下
2009/10/13 Javascript
Javascript结合css实现网页换肤功能
2009/11/02 Javascript
jquery实现翻动fadeIn显示的方法
2015/03/05 Javascript
使用snowfall.jquery.js实现爱心满屏飞的效果
2017/01/05 Javascript
详解VueJs异步动态加载块
2017/03/09 Javascript
angular学习之ngRoute路由机制
2017/04/12 Javascript
js将当前时间格式化为 年-月-日 时:分:秒的实现代码
2018/01/20 Javascript
vue表单自定义校验规则介绍
2018/08/28 Javascript
详解jQuery中的getAll()和cleanData()
2019/04/15 jQuery
jQuery动态生成的元素绑定事件操作实例分析
2019/05/04 jQuery
Vue通过for循环随机生成不同的颜色或随机数的实例
2019/11/09 Javascript
JavaScript中arguments的使用方法详解
2020/12/20 Javascript
pygame播放音乐的方法
2015/05/19 Python
Python数据库的连接实现方法与注意事项
2016/02/27 Python
AI人工智能 Python实现人机对话
2017/11/13 Python
django反向解析URL和URL命名空间的方法
2018/06/05 Python
python xpath获取页面注释的方法
2019/01/14 Python
Python实现某论坛自动签到功能
2019/08/20 Python
adidas泰国官网:adidas TH
2020/07/11 全球购物
测试时代收集的软件测试面试题
2013/09/25 面试题
竞选演讲稿范文
2013/12/28 职场文书
班级旅游计划书
2014/05/03 职场文书
另类冲刺标语
2014/06/24 职场文书
通知的写法
2015/04/23 职场文书
病房管理制度范本
2015/08/06 职场文书
消防安全主题班会
2015/08/12 职场文书
小学体育组工作总结
2015/08/13 职场文书
python turtle绘图命令及案例
2021/11/23 Python
「睡美人」爱洛公主粘土人开订
2022/03/22 日漫
Python使用pandas导入csv文件内容的示例代码
2022/12/24 Python