zoukankan      html  css  js  c++  java
  • js实现一些跨浏览器的事件方法

      用JavaScript实现事件的绑定,移除,以及一些常用的事件属性的获取,时常要考虑到在不同浏览器下的兼容性,下面给出了一个跨浏览器的事件对象:

    var EventUtil = {
        on: function(element, type, handler) {/* 添加事件 */
            if (element.addEventListener) {
                element.addEventListener(type, handler, false);
            } else if (element.attachEvent) {//IE  注意:此时事件处理程序会在全局作用域中运行,因此用attachEvent绑定的事件,此时在事件处理函数里的this 等于window,使用时要注意
                element.attachEvent("on" + type, handler);
            } else {
                element["on" + type] = handler;
            }
        },
    
        off: 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] = null;
            }
        },
    
        getEvent: function(event) {/* 返回对event对象的引用 */
            return event ? event : window.event;
        },
    
        getTarget: function(event) {/* 返回事件的目标 */
            return event.target || event.srcElement;
        },
    
        preventDefault: function(event) { /* 取消事件的默认行为 */
            if (event.preventDefault) {
                event.preventDefault();
            } else {
                event.returnValue = false;
            }
        },
    
        stopPropagation: function(event) {/* 阻止事件冒泡 */
            if (event.stopPropagation) {
                event.stopPropagation();
            } else {
                event.cancelBubble = true;
            }
        },
    
        /* mouseover 和mouserout 这两个事件都会涉及把鼠标指针从一个元素的边界之内移动到另一个元素的边界之内。*/
        getRelatedTarget: function(event) {
            if (event.relatedTarget) {
                return event.relatedTarget;
            } else if (event.toElement) {//IE8 mouserout事件
                return event.toElement;
            } else if (event.fromElement) {//IE8 mouseover事件
                return event.fromElement;
            } else {
                return null;//其他事件
            }
        }
    };

    调用如下:

    EventUtil.on(document, "click", function(event){//为document元素绑定click事件
        event = EventUtil.getEvent(event);//获取event事件对象
        alert("Screen coordinates: " + event.screenX + "," + event.screenY);
    });

    文章参考自《JavaScript高级程序设计第三版》

  • 相关阅读:
    Java锁到底锁的到底是哪个对象?什么是锁对象
    什么是正向代理,什么是反向代理
    到底什么是线程安全
    为什么要使用接口,直接写是实现类不行吗
    Nginx配置学习(一)
    Zookeeper集群节点数量为什么要是奇数个?
    Redis 5 单实例数据迁移到Cluster
    Centos8安装Nginx1.18.0
    vmware workstation15 桥接模式互ping不通,虚机可以连通局域网其他机器解决方法
    MongoDB double类型保留2位小数
  • 原文地址:https://www.cnblogs.com/ww03/p/6000588.html
Copyright © 2011-2022 走看看