js跨浏览器的事件侦听器和事件对象的使用方法


Posted in Javascript onDecember 17, 2015

本文特意为跨浏览器实现添加事件侦听器和跨浏览器事件对象的使用方法做了下总结,并把这些方法打包,欢迎大家学习。
打包的一个EventUtil对象

var EventUtil = {
    // 添加侦听事件
    addEventListener:function (element, type, handler) {
      // IE9+、Firefox、Safari、chrome和Opera
      if(element.addEventListener) {
        element.addEventListener(type, handler, false);
      }
      // IE8-
      else if(element.attachEvent) {
        element.attachEvent("on" + type, handler);
      }
    },
    
    // 移除侦听事件
    removeEventListener:function (element, type, handler) {
      // IE9+、Firefox、Safari、chrome和Opera
      if(element.addEventListener) {
        element.removeEventListener(type, handler, false);
      }
      // IE8-
      else if(element.attachEvent) {
        element.detachEvent("on" + type, handler);
      }
    },
    
    // 获取事件对象
    getEvent:function(event) {
      if(typeof event == "undefined") {
        event = window.event; // IE浏览器
      }
      return event;
    },
    
    // 获取触发事件的元素
    getTarget:function(event){
      if(typeof event.srcElement == "undefined") {
        return event.target;
      }else {
        return event.srcElement; // IE浏览器
      }
    },
    
    // 获取事件类型
    getType:function(event) {
      return event.type;
    },
    
    // 获取按键键码
    getCharCode:function(event) {
      if(typeof event.keyCode == "number") {
        return event.keyCode; // IE8-、Firefox和opera
      }else {
        return event.charCode; 
      }
    },
    
    // 获取鼠标相对于文档的位置,即页面坐标位置
    getPagePosition:function(event) {
      var pageX = event.pageX,
        pageY = event.pageY;
      if(pageX == undefined) {
        pageX = event.clientX + (document.body.scrollLeft || document.documentElement.scrollLeft);
      }
      if(pageY == undefined) {
        pageY = event.clientY + (document.body.scrollTop || document.documentElement.scrollTop);
      }
      return {
        pageX:pageX,
        pageY:pageY
      };
    },
    
    // 阻止事件的默认行为
    preventDefault:function(event) {
      if(event.preventDefault){
        event.preventDefault();
      }else {
        event.returnValue = false; // IE浏览器
      }
    },
    
    // 阻止事件冒泡
    stopPropagation:function(event) {
      if(typeof event.cancelBubble == "undefined") {
        event.stopPropagation();
      }else {
        event.cancelBubble = true; // IE浏览器
      }
    }
  };

测试代码

<div id="box" style="color:red;width: 100%;height:200px;" >
  <input type="button" value="点击" id="btn" />
</div>
<a href="http://www.test.com" id="a">test</a>
var box = document.querySelector("#box");
  box.onclick = function(event) {
    event = EventUtil.getEvent(event);
    alert(EventUtil.getType(event));
    alert(EventUtil.getTarget(event));
  };
  var input = document.querySelector("input");
  input.onclick = function(event) {
    event = EventUtil.getEvent(event);
    EventUtil.stopPropagation(event);
  };
  
  var a = document.getElementById("a");
  a.onclick = function(event) {
    event = EventUtil.getEvent(event);
    EventUtil.preventDefault(event);
  };

以上就是跨浏览器实现添加事件侦听器和跨浏览器事件对象的使用方法,希望对大家的学习有所帮助。

Javascript 相关文章推荐
jQuery之选项卡的简单实现
Feb 28 Javascript
JavaScript实现在数组中查找不同顺序排列的字符串
Sep 26 Javascript
Juery解决tablesorter中文排序和字符范围的方法
May 06 Javascript
理解javascript对象继承
Apr 17 Javascript
JS模仿腾讯图片站的图片翻页按钮效果完整实例
Jun 21 Javascript
html5+CSS 实现禁止IOS长按复制粘贴功能
Dec 28 Javascript
Webpack执行命令参数详解
Jun 17 Javascript
想用好React的你必须要知道的一些事情
Jul 24 Javascript
node.js的Express服务器基本使用教程
Jan 09 Javascript
element-ui带输入建议的input框踩坑(输入建议空白以及会闪出上一次的输入建议问题)
Jan 15 Javascript
如何实现双向绑定mvvm的原理实现
May 28 Javascript
jquery中为什么能用$操作
Jun 18 jQuery
js调出上下文菜单的实例
Dec 17 #Javascript
快速掌握WordPress中加载JavaScript脚本的方法
Dec 17 #Javascript
JSONObject使用方法详解
Dec 17 #Javascript
JS实现alert中显示换行的方法
Dec 17 #Javascript
JavaScript中Function函数与Object对象的关系
Dec 17 #Javascript
jQuery实现进度条效果代码
Dec 17 #Javascript
JavaScript创建对象的方式小结(4种方式)
Dec 17 #Javascript
You might like
SESSION信息保存在哪个文件目录下以及能够用来保存什么类型的数据
2012/06/17 PHP
PHP进程通信基础之信号
2017/02/19 PHP
PHP开发之用微信远程遥控服务器
2018/01/25 PHP
php+redis实现商城秒杀功能
2020/11/19 PHP
Laravel等框架模型关联的可用性浅析
2019/12/15 PHP
js选取多个或单个元素的实现代码(用class)
2012/08/22 Javascript
js弹出窗口之弹出层的小例子
2013/06/17 Javascript
struts2+jquery+json实现异步加载数据(自写)
2013/06/24 Javascript
JS判断对象是否存在的10种方法总结
2013/12/23 Javascript
js点击出现悬浮窗效果不使用JQuery插件
2014/01/20 Javascript
jQuery瀑布流插件Wookmark使用实例
2014/04/02 Javascript
jQuery提示效果代码分享
2014/11/20 Javascript
限制上传文件大小和格式的jQuery插件实例
2015/01/24 Javascript
JavaScript实现Base64编码转换
2016/04/23 Javascript
基于Bootstrap的Metronic框架实现条码和二维码的生成及打印处理操作
2016/08/29 Javascript
使用开源工具制作网页验证码的方法
2016/10/17 Javascript
AngularJS使用ng-Cloak阻止初始化闪烁问题的方法
2016/11/03 Javascript
Angularjs 动态添加指令并绑定事件的方法
2017/04/13 Javascript
js canvas实现擦除效果示例代码
2017/04/26 Javascript
详解windows下vue-cli及webpack 构建网站(三)使用组件
2017/06/17 Javascript
React Native之TextInput组件解析示例
2017/08/22 Javascript
详解angularjs4部署文件过大解决过程
2018/12/05 Javascript
解析JS在获取当前月的最后一天遇到的坑
2019/08/30 Javascript
[01:16]2014DOTA2 TI专访C9战队EE:中国五强中会占三席
2014/07/10 DOTA
python实现简单登陆系统
2018/10/18 Python
python实现淘宝秒杀脚本
2020/06/23 Python
python 爬取B站原视频的实例代码
2020/09/09 Python
jupyter使用自动补全和切换默认浏览器的方法
2020/11/18 Python
Html5实现用户注册自动校验功能实例代码
2016/05/24 HTML / CSS
外贸销售员求职的自我评价
2013/11/23 职场文书
酒店员工职业生涯规划
2014/02/25 职场文书
村干部承诺书
2014/03/28 职场文书
班组长竞聘书
2014/03/31 职场文书
土地租赁协议书
2015/01/29 职场文书
2015年个人招商工作总结
2015/04/25 职场文书
教你解决往mysql数据库中存入汉字报错的方法
2021/05/06 MySQL