您现在的位置:
  1. 首页
  2. 建网相关
  3. JavaScript获得鼠标坐标(兼容IE/Firefox等浏览器)

JavaScript获得鼠标坐标(兼容IE/Firefox等浏览器)

用 javaScript 获取当页面上鼠标(光标)位置在许多情况下都会用到,比如拖放,悬停提示(tooltip) 等等。

当然,这里我们依然要面对浏览器的兼容问题,在不同的浏览器下,对这些相关的属性处理方式也不同,本文详细介绍了浏览器在处理这些属性时的差异和最终的解决方法。

  1. <script type="text/javascript">  
  2.   
  3. // 说明:获取鼠标位置  
  4. // 整理:http://www.web600.net  
  5. // 来源:http://www.webreference.com  
  6.   
  7. function mousePosition(ev){  
  8. if(ev.pageX || ev.pageY){  
  9.        return {x:ev.pageX, y:ev.pageY};  
  10. }  
  11. return {  
  12.        x:ev.clientX + document.documentElement.scrollLeft - document.body.clientLeft,  
  13.        y:ev.clientY + document.documentElement.scrollTop   - document.body.clientTop  
  14. };  
  15. }   
  16. </script>  

由于这个需求我们经常用到,所以我们将这段代码独立成一篇文章,供大家查询。

使用方式:

  1. document.onmousemove = mouseMove;  
  2.   
  3. function mouseMove(ev){  
  4. ev = ev || window.event;  
  5. var mousePos = mousePosition(ev);  
  6. }   

我们首先要声明一个 evnet 对象,无论移动、点击、按键等,都会激活一个 evnet ,在 Internet Explorer 里,   event 是全局变量,会被存储在 window.event 里。

在 Firefox 或者其他浏览器,event 会被相应的函数获取。

当我们将mouseMove函数赋值于document.onmousemove,mouseMove 会获取鼠标移动事件。

为了让 ev 在所有浏览器下获取了 event 事件,在Firefox下"||window.event"将不起作用,因为ev已经有了赋值。在Internet Explorer  中 ev 为空,所以得到 window.event 。

因为在这里我们需要多次获取鼠标位置,所以我们设计了一个 mousePosition 函数,它包含一个参数 : event

因为我们要在 IE 和其他浏览器下运行,Firefox 和其他浏览器用 event.pageX 和 event.pageY 来表示鼠标相对于文档的位置。

如果你有一个 500*500 的窗口并且你的鼠标在绝对中间,那么 pageX 和 pageY   的值都是 250,如果你向下滚动   500, 那么 pageY 将变成 750。

IE 正好相反,它使用 event.clientX 和 event.clientY 表示鼠标相当于窗口的位置,而不是文档。

在同样的例子中,如果你向下滚动500,clientY 依然是 250,因此,我们需要添加 scrollLeftscrollTop 这两个相对于文档的属性。

最后,IE 中文档并不是从 0,0 开始,而是通常有一个小的边框(通常是 2 象素),边框的大小定义在 document.body.clientLeftclientTop 中,我们也把这些加进去。

现在,我们已经用 mousePosition 函数解决了坐标问题。

下面是完整的事例,将其保存为HTML即可运行:

HTML代码
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  2. <html xmlns="http://www.w3.org/1999/xhtml">  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />  
  5. <meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7"/>  
  6. <meta name="auther" content="fq" />  
  7. <title>获取鼠标坐标</title>  
  8. </head>  
  9. <body>  
  10. <script type="text/javascript">  
  11. function mousePosition(ev){  
  12.     if(ev.pageX || ev.pageY){  
  13.    return {x:ev.pageX, y:ev.pageY};  
  14.    }  
  15.    return {  
  16.    x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,  
  17.    y:ev.clientY + document.body.scrollTop   - document.body.clientTop  
  18.    };  
  19. }  
  20.   
  21. function mouseMove(ev){  
  22. evev = ev || window.event;  
  23. var mousePos = mousePosition(ev);  
  24. document.getElementById(‘xxx’).value = mousePos.x;  
  25.    document.getElementById(‘yyy’).value = mousePos.y;  
  26. }  
  27.   
  28. document.onmousemove = mouseMove;  
  29. </script>  
  30. X:<input id="xxx" type="text" />   Y:<input id="yyy" type="text" />  
  31. </body>  
  32. </html>  

 其他鼠标事件:

onmousedown 当用户用任何鼠标按钮单击对象时触发。

onmouseenter 当用户将鼠标指针移动到对象内时触发。

onmouseleave 当用户将鼠标指针移出对象边界时触发。

onmousemove 当用户将鼠标划过对象时触发。

onmouseout 当用户将鼠标指针移出对象边界时触发。

onmouseover 当用户将鼠标指针移动到对象内时触发。

onmouseup 当用户在鼠标位于对象之上时释放鼠标按钮时触发。

onmousewheel 当鼠标滚轮按钮旋转时触发。

onmove 当对象移动时触发。

onmoveend 当对象停止移动时触发。

onmovestart 当对象开始移动时触发。

还有这些可能你也想看看:

发表评论

必填

必填