zoukankan      html  css  js  c++  java
  • window.event对象在IE与DOM中的异同

    window.event对象在IE与DOM中的区别

    1、window.event

    IE:有window.event对象

    DOM:没有window.event对象。可以通过给函数的参数传递event对象。如onmousemove=domousemove(event)

    <input type="button" onmousemove="showDiv(event);"//event不需要加引号 
    function showDiv(event) 
    { 
    var event=window.event||event; 
    event.clientX; 
    event.clientY; 
    }

    2 、鼠标当前坐标

    通用:两者都有event.clientX和event.clientY属性。

    3 、鼠标当前坐标(加上滚动条滚过的距离)

    DOM:event.pageX和event.pageY

    IE9以上:event.pageX和event.pageY

    IE6/7/8不识别event.pageX和event.pageY,解决办法:

    PageY=clientY+scrollTop-clientTop;(只讨论Y轴,X轴同理,下同)
    页面上的位置=可视区域位置+页面滚动条切去高度-自身border高度

    4、鼠标到屏幕的距离

    通用:两者都有event.screenX和event.screenY属性。

    5、阻止冒泡

    IE:event.canceBubble=true;

    DOM:event.stopPropagation();

    6、阻止默认事件

    IE:event.returnValue=false;

    DOM:event.preventDefault();

    7、获取事件的目标

    IE:event.srcElement;

    DOM:event.target;

    8、为元素绑定事件(现代方法)

    IE:element.attachevent(”onclick”, func);。

    DOM:element.addeventlistener(”click”, func, true)。

    通用:element.onclick=func。虽然都可以使用onclick事件,但是onclick和上面两种方法的效果是不一样的, onclick只有执行一个过程,而attachevent和addeventlistener执行的是一个过程列表,也就是多个过程。

    例如:element.attachevent(”onclick”, func1);element.attachevent(”onclick”, func2)这样func1和func2都会被执行。

  • 相关阅读:
    Android中SharedPreferences介绍和使用方法
    功能(一):添加影像服务图层
    二、策略模式
    一、简单工厂模式
    C#重点内容之:接口(interface)(一)网络初级示例
    Windows API编程(一)完整的示范程序
    秩序让生活趋向于和谐
    模板专题:类模板
    模板专题:函数模板
    STL之vector详解
  • 原文地址:https://www.cnblogs.com/yddlvo/p/4641539.html
Copyright © 2011-2022 走看看