• commonJS — 事件处理(for Event)


    for Event

    github: https://github.com/laixiangran/commonJS/blob/master/src/forEvent.js

    代码

    (function(window, undefined) {
    
        var com = window.COM = window.COM || {};
    
        com.$E = {
            // 添加事件
            addEvent: 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;
                }
            },
    
            // 移除事件处理程序
            removeEvent: 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;
                }
            },
    
            // 获取对event对象的引用
            getEvent: function(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; // IE
                }
            },
    
            // 阻止事件流(由于IE不支持事件捕获,该方法只能阻止事件冒泡)
            stopPropagation: function(event) {
                if (event.stopPropagation) {
                    event.stopPropagation();
                } else {
                    event.cancelBubble = true; // IE
                }
            },
    
            // 获取事件相关元素
            getRelatedTarget: function(event) {
                if (event.relatedTarget) {
                    return event.relatedTarget;
                } else if (event.toElement) { // IE下的mouseout事件
                    return event.toElement;
                } else if (event.fromElement) { // IE下的mouseover事件
                    return event.fromElement;
                } else {
                    return null;
                }
            },
    
            // 获取鼠标按钮值(0:主鼠标按钮(一般是鼠标左键),1:中间的鼠标按钮(鼠标滚轮按钮),2:次鼠标按钮(一般是鼠标右键))
            getButton: function(event) {
                //  检测是否支持DOM版鼠标事件
                if (document.implementation.hasFeature("MouseEvents", "2.0")) {
                    return event.button;
                } else { // IE
                    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;
                    }
                }
            },
    
            // 获取鼠标滚轮增量值
            getWheelDelta: function(event) {
                // 当向前滚动鼠标滚轮时,wheelDelta是120的倍数;当向后滚动鼠标滚轮时,wheelDelta是-120的倍数
                if (event.wheelDelta){
                    // Opera 9.5之前的版本中,wheelDelta值的正负号是颠倒的,则这里需要使用浏览器检测技术来确定实际的值
                    return (com.$B.engine.opera && com.$B.engine.opera < 9.5 ?
                            -event.wheelDelta : event.wheelDelta);
                } else { // Firefox下,有关鼠标滚轮的信息则保存在detail属性中,当向前滚动鼠标滚轮时,这个属性的值是-3的倍数,当向后滚动鼠标滚轮时,这个属性的值是3的倍数
                    return -event.detail * 40;
                }
            },
    
            // 获取键盘事件中的字符ASCII编码
            getCharCode: function(event) {
                if (typeof event.charCode == "number") {
                    return event.charCode;
                } else {
                    return event.keyCode; // IE8及之前版本和Opera
                }
            },
    
            // 获取剪贴板内容
            getClipboardText: function(event) {
                var clipboardData = (event.clipboardData || window.clipboardData);
    
                // clipboardData.getData()用于从剪贴板中取得数据,它接受一个参数,即要取得的数据的格式
                // 在IE中,有两种数据格式:"text"和"URL"
                // 在Firefox、Safari和Chrome中,这个参数是一种MIME类型;不过,可以用"text"代表"text/plain"
                return clipboardData.getData("text");
            },
    
            // 设置剪切板内容,设置成功返回true
            setClipboardText: function(event, value) {
                if (event.clipboardData) {
                    // 由于Safari和Chrome的clipboardData.setData()方法不能识别"text"类型,则这里只能写"text/plain"
                    return event.clipboardData.setData("text/plain", value);
                } else if (window.clipboardData) {
                    return window.clipboardData.setData("text", value);
                }
            }
        }
    }(window));
  • 相关阅读:
    Flask中路由系统、Flask的参数及app的配置
    linux之master和minion
    linux之docker学习
    项目的发布(nginx、uwsgi、django、virtualenv、supervisor)
    Linux下安装和使用nginx
    linux下主从同步和redis的用法
    论图像识别的预处理技术
    图像技术分析 图像编辑器核心技术
    C++ Primer 第九章 顺序容器
    图像灰度化公式 颜色空间用途说明
  • 原文地址:https://www.cnblogs.com/laixiangran/p/5174851.html
Copyright © 2020-2023  润新知