zoukankan      html  css  js  c++  java
  • ie与firefox下的event使用说明与详细区别

    ie与firefox event的详细区别
    window.event 
    IE:有window.event对象 
    FF:没有window.event对象。可以通过给函数的参数传递event对象。如onmousemove=doMouseMove(event) 
    鼠标当前坐标 
    IE:event.x和event.y。 
    FF:event.pageX和event.pageY。 
    通用:两者都有event.clientX和event.clientY属性。 

    鼠标当前坐标(加上滚动条滚过的距离) 
    IE:event.offsetX和event.offsetY。 
    FF:event.layerX和event.layerY。 
    标签的x和y的坐标位置:style.posLeft 和 style.posTop 
    IE:有。 
    FF:没有。 
    通用:object.offsetLeft 和 object.offsetTop。 

    窗体的高度和宽度 
    IE:document.body.offsetWidth和document.body.offsetHeight。注意:此时页面一定要有body标签。
    FF:window.innerWidth和window.innerHegiht,以及document.documentElement.clientWidth和document.documentElement.clientHeight。 
    通用:document.body.clientWidth和document.body.clientHeight。 

    添加事件 
    IE:element.attachEvent(”onclick”, func);。 
    FF:element.addEventListener(”click”, func, true)。 
    通用:element.onclick=func。虽然都可以使用onclick事件,但是onclick和上面两种方法的效果是不一样的,onclick只有执行一个过程,而attachEvent和addEventListener执行的是一个过程列表,也就是多个过程。例如:element.attachEvent(”onclick”, func1);element.attachEvent(”onclick”, func2)这样func1和func2都会被执行。 

    标签的自定义属性 
    IE:如果给标签div1定义了一个属性value,可以div1.value和div1[”value”]取得该值。 
    FF:不能用div1.value和div1[”value”]取。 
    通用:div1.getAttribute(”value”)。 

    父节点、子节点和删除节点 
    IE:parentElement、parement.children,element.romoveNode(true)。 
    FF:parentNode、parentNode.childNodes,node.parentNode.removeChild(node)。

    ------------------------------------------------------------------------------------

    鼠标事件

    鼠标移动到目标元素上的那一刻,首先触发mouseover
    之后如果光标继续在元素上移动,则不断触发mousemove
    如果按下鼠标上的设备(左键,右键,滚轮……),则触发mousedown
    当设备弹起的时候触发mouseup
    目标元素的滚动条发生移动时(滚动滚轮/拖动滚动条。。)触发scroll
    滚动滚轮触发mousewheel,这个要区别于scroll
    鼠标移出元素的那一刻,触发mouseout

    事件注册

    平常我们绑定事件的时候用dom.onxxxx=function(){}的形式
    这种方式是给元素的onxxxx属性赋值,只能绑定有一个处理句柄。
    但很多时候我们需要绑定多个处理句柄到一个事件上,而且还可能要动态的增删某个处理句柄
    下面的事件注册方式就能解决这个需求。
    先介绍一下四个方法

     
    //IE以外
    target.addEventListener(type,listener,useCapture)
    target.removeEventListener(type,listener,useCapture);
    target      :文档节点、document、window 或 XMLHttpRequest。 
    type        :字符串,事件名称,不含“on”,比如“click”、“mouseover”、“keydown”等。 
    listener    :实现了 EventListener 接口或者是 JavaScript 中的函数。 
    useCapture  :是否使用捕捉,一般用 false//IE
    target.attachEvent(type, listener);
    target.detachEvent(type, listener);
    target      :文档节点、document、window 或 XMLHttpRequest。
    type        :字符串,事件名称,含“on”,比如“onclick”、“onmouseover”、“onkeydown”等。
    listener    :实现了 EventListener 接口或者是 JavaScript 中的函数。
    
    两者使用的原理:可对执行的优先级不一样,实例讲解如下:
    ele.attachEvent("onclick",method1); 
    ele.attachEvent("onclick",method2); 
    ele.attachEvent("onclick",method3);
    执行顺序为method3->method2->method1 
    
    ele.addEventListener("click",method1,false); 
    ele.addEventListener("click",method2,false); 
    ele.addEventListener("click",method3,false);
    执行顺序为method1->method2->method3
    
    兼容后的方法
    var func = function(){};
    
    //例:addEvent(window,"load",func)
    function addEvent(elem, type, fn) {
        if (elem.attachEvent) {
            elem.attachEvent('on' + type, fn);
            return;
        }
        if (elem.addEventListener) {
            elem.addEventListener(type, fn, false);
        }
    }
    
    //例:removeEvent(window,"load",func)
    function removeEvent(elem, type, fn) {
        if (elem.detachEvent) {
            elem.detachEvent('on' + type, fn);
            return;
        }
        if (elem.removeEventListener) {
            elem.removeEventListener(type, fn, false);
        }
    }
     

    获取事件对象和事件源(触发事件的元素)

    function eventHandler(e){
        //获取事件对象
        e = e || window.event;//IE和Chrome下是window.event FF下是e
        //获取事件源
        var target = e.target || e.srcElement;//IE和Chrome下是srcElement FF下是target
    }

    取消事件默认行为(例如点击一个<a>后不跳转页面而是执行一个函数)

     
    function eventHandler(e) {
        e = e || window.event;
        // 防止默认行为
        if (e.preventDefault) {
            e.preventDefault();//IE以外
        } else {
            e.returnValue = false;//IE
            
            //注意:这个地方是无法用return false代替的
            //return false只能取消元素
        }
    }
     

    阻止事件冒泡

     
    function myParagraphEventHandler(e) {
        e = e || window.event;
        if (e.stopPropagation) {
            e.stopPropagation();//IE以外
        } else {
            e.cancelBubble = true;//IE
        }
    }
     

    事件委托
    例如,你有一个很多行的大表格,在每个<tr>上绑定点击事件是个非常危险的想法,因为性能是个大问题。流行的做法是使用事件委托。
    事件委托描述的是将事件绑定在容器元素上,然后通过判断点击的target子元素的类型来触发相应的事件。
    事件委托依赖于事件冒泡,如果事件冒泡到table之前被禁用的话,那以下代码就无法工作了。

     
    myTable.onclick = function () {
        e = e || window.event;
        var targetNode = e.target || e.srcElement;
    
        // 测试如果点击的是TR就触发
        if (targetNode.nodeName.toLowerCase() === 'tr') {
            alert('You clicked a table row!');
        }
    }
     

     

  • 相关阅读:
    如何用Python实现网络请求库中的UR解析器,面试必学
    为什么有人说 Python 多线程是鸡肋?
    router-view 与 动态组件 区别
    keep-alive
    vue 客户端渲染和服务端渲染
    js 数组对象深拷贝
    vue template标签
    Jquery中的日历插件
    HTML5中的canvas基本概念及绘图
    HTML5中的音视频处理
  • 原文地址:https://www.cnblogs.com/dtdxrk/p/2524103.html
Copyright © 2011-2022 走看看