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 checkbox复选框全选功能简单实例
Oct 09 Javascript
jquery 操作两个select实现值之间的互相传递
Mar 07 Javascript
javascript实现类似java中getClass()得到对象类名的方法
Jul 27 Javascript
微信+angularJS的SPA应用中用router进行页面跳转,jssdk校验失败问题解决
Sep 09 Javascript
微信小程序 基础组件与导航组件详细介绍
Feb 21 Javascript
vue的Virtual Dom实现snabbdom解密
May 03 Javascript
基于JQuery的Ajax方法使用详解
Aug 16 jQuery
checkbox:click事件触发span元素内容改变的方法
Sep 11 Javascript
vue中使用heatmapjs的示例代码(结合百度地图)
Sep 05 Javascript
基于Vue实现可以拖拽的树形表格实例详解
Oct 18 Javascript
elementUI Tree 树形控件的官方使用文档
Apr 25 Javascript
微信小程序云开发详细教程
May 16 Javascript
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
深入了解PHP类Class的概念
2012/06/14 PHP
PHP读取数据库并按照中文名称进行排序实现代码
2013/01/29 PHP
PHP中模拟处理HTTP PUT请求的例子
2014/07/22 PHP
CI框架中site_url()和base_url()的区别
2015/01/07 PHP
TP3.2框架分页相关实现方法分析
2020/06/03 PHP
javascript document.execCommand() 常用解析
2009/12/14 Javascript
JS去除右边逗号的简单方法
2013/07/03 Javascript
javascript代码运行不出来执行错误的可能情况整理
2013/10/18 Javascript
jquery live()重复绑定的解决方法介绍
2014/01/03 Javascript
JqueryMobile动态生成listView并实现刷新的两种方法
2014/03/05 Javascript
jquery+css实现的红色线条横向二级菜单效果
2015/08/22 Javascript
浅谈Nodejs观察者模式
2015/10/13 NodeJs
什么是JavaScript中的结果值?
2016/10/08 Javascript
ES6新数据结构Map功能与用法示例
2017/03/31 Javascript
微信小程序使用npm支持踩坑
2018/11/07 Javascript
JavaScript中this用法学习笔记
2019/03/17 Javascript
node.js 基于cheerio的爬虫工具的实现(需要登录权限的爬虫工具)
2019/04/10 Javascript
理解python正则表达式
2016/01/15 Python
Linux下python制作名片示例
2018/07/20 Python
从0开始的Python学习016异常
2019/04/08 Python
Python3实现定时任务的四种方式
2019/06/03 Python
Spring Cloud Feign高级应用实例详解
2019/12/10 Python
tensorflow指定CPU与GPU运算的方法实现
2020/04/21 Python
Python如何避免文件同名产生覆盖
2020/06/09 Python
使用HTML5 Canvas为图片填充颜色和纹理的教程
2016/03/21 HTML / CSS
HTML5 video循环播放多个视频的方法步骤
2020/08/06 HTML / CSS
Ralph Lauren拉夫·劳伦美国官网:带有浓郁美国气息的高品味时装品牌
2017/11/01 全球购物
军训自我鉴定
2014/01/22 职场文书
人事助理自荐信
2014/02/02 职场文书
法人代表授权委托书
2014/04/08 职场文书
优秀实习生主要事迹
2014/05/29 职场文书
学生检讨书怎么写
2015/05/07 职场文书
2016年教师新年寄语
2015/08/18 职场文书
《从现在开始》教学反思
2016/02/16 职场文书
《没有任何借口》读后感:完美的执行能力
2020/01/07 职场文书
叶县这家生产军用电台的兵工厂,人称“四机部”,走出一上将
2022/02/18 无线电