• 跨浏览器的事件侦听器和事件对象


    今天特意为跨浏览器实现添加事件侦听器和跨浏览器事件对象的使用方法做了下总结,并把这些方法打包。

    打包的一个EventUtil对象

     1   var EventUtil = {
     2         // 添加侦听事件
     3         addEventListener:function (element, type, handler) {
     4             // IE9+、Firefox、Safari、chrome和Opera
     5             if(element.addEventListener) {
     6                 element.addEventListener(type, handler, false);
     7             }
     8             // IE8-
     9             else if(element.attachEvent) {
    10                 element.attachEvent("on" + type, handler);
    11             }
    12         },
    13         
    14         // 移除侦听事件
    15         removeEventListener:function (element, type, handler) {
    16             // IE9+、Firefox、Safari、chrome和Opera
    17             if(element.addEventListener) {
    18                 element.removeEventListener(type, handler, false);
    19             }
    20             // IE8-
    21             else if(element.attachEvent) {
    22                 element.detachEvent("on" + type, handler);
    23             }
    24         },
    25         
    26         // 获取事件对象
    27         getEvent:function(event) {
    28             if(typeof event == "undefined") {
    29                 event = window.event; // IE浏览器
    30             }
    31             return event;
    32         },
    33         
    34         // 获取触发事件的元素
    35         getTarget:function(event){
    36             if(typeof event.srcElement == "undefined") {
    37                 return event.target;
    38             }else {
    39                 return event.srcElement; // IE浏览器
    40             }
    41         },
    42         
    43         // 获取事件类型
    44         getType:function(event) {
    45             return event.type;
    46         },
    47         
    48         // 获取按键键码
    49         getCharCode:function(event) {
    50             if(typeof event.keyCode == "number") {
    51                 return event.keyCode; // IE8-、Firefox和opera
    52             }else {
    53                 return event.charCode; 
    54             }
    55         },
    56         
    57         // 获取鼠标相对于文档的位置,即页面坐标位置
    58         getPagePosition:function(event) {
    59             var pageX = event.pageX,
    60                 pageY = event.pageY;
    61             if(pageX == undefined) {
    62                 pageX = event.clientX + (document.body.scrollLeft || document.documentElement.scrollLeft);
    63             }
    64             if(pageY == undefined) {
    65                 pageY = event.clientY + (document.body.scrollTop || document.documentElement.scrollTop);
    66             }
    67             return {
    68                 pageX:pageX,
    69                 pageY:pageY
    70             };
    71         },
    72         
    73         // 阻止事件的默认行为
    74         preventDefault:function(event) {
    75             if(event.preventDefault){
    76                 event.preventDefault();
    77             }else {
    78                 event.returnValue = false; // IE浏览器
    79             }
    80         },
    81         
    82         // 阻止事件冒泡
    83         stopPropagation:function(event) {
    84             if(typeof event.cancelBubble == "undefined") {
    85                 event.stopPropagation();
    86             }else {
    87                 event.cancelBubble = true; // IE浏览器
    88             }
    89         }
    90     }; 

    测试代码

    1   <div id="box" style="color:red; 100%;height:200px;" >
    2         <input type="button" value="点击" id="btn" />
    3     </div>
    4     <a href="http://www.test.com" id="a">test</a>
     1     var box = document.querySelector("#box");
     2     box.onclick = function(event) {
     3         event = EventUtil.getEvent(event);
     4         alert(EventUtil.getType(event));
     5         alert(EventUtil.getTarget(event));
     6     };
     7     var input = document.querySelector("input");
     8     input.onclick = function(event) {
     9         event = EventUtil.getEvent(event);
    10         EventUtil.stopPropagation(event);
    11     };
    12     
    13     var a = document.getElementById("a");
    14     a.onclick = function(event) {
    15         event = EventUtil.getEvent(event);
    16         EventUtil.preventDefault(event);
    17     };
  • 相关阅读:
    linux tftp 服务
    AtomicInteger
    深入理解JVM(三)——垃圾收集策略具体解释
    Android 虚拟现实(virtual reality)入门指南
    Java千百问_05面向对象(005)_接口和抽象类有什么差别
    postman发送json格式的post请求
    什么是Session分布式共享
    如何设计一个单点登录系统(3)?
    如何设计一个单点登录系统(2)?
    如何设计一个单点登录系统(1)?
  • 原文地址:https://www.cnblogs.com/yuanke/p/5045821.html
Copyright © 2020-2023  润新知