javascript兼容性获取鼠标坐标

 用 javascript 获取当页面上鼠标(光标)位置在许多情况下都会用到,比如拖放,悬停提示(tooltip) 等等。当然,这里我们依然要面对浏览器的兼容问题,在不同的浏览器下,对这些相关的属性处理方式也不同,本文详细介绍了浏览器在处理这些属性时的差异和最终的解决方法。

JavaScript代码
  1. <script type="text/javascript">  
  2. function mousePosition(ev){  
  3.     if(ev.pageX || ev.pageY){  
  4.         return {x:ev.pageX, y:ev.pageY};  
  5.     }  
  6.     return {  
  7.         x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,  
  8.         y:ev.clientY + document.body.scrollTop - document.body.clientTop  
  9.     };  
  10. }  
  11. </script>  

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

使用方式:

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

我们首先要声明一个 evnet 对象,无论移动、点击、按键等,都会激活一个 evnet ,在 Internet Explorer 里, event 是全局变量,会被存储在 window.event 里. 在 firefox 或者其他浏览器,event 会被相应的函数获取.当我们将mouseMove函数赋值于document.onmousemove,mouseMove 会获取鼠标移动事件。

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

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

因为我们要在 MSIE 和其他浏览器下运行,Firefox 和其他浏览器用 event.pageX 和 event.pageY 来表示鼠标相对于文档的位置,如果你有一个 500*500 的窗口并且你的鼠标在绝对中间,那么 pageX 和 pageY 的值都是 250,如果你向下滚动 500, 那么 pageY 将变成 750。


MSIE 正好相反,它使用 event.clientX 和 event.clientY 表示鼠标相当于窗口的位置,而不是文档。在同样的例子中,如果你向下滚动 500,clientY 依然是 250,因此,我们需要添加 scrollLeft 和 scrollTop 这两个相对于文档的属性。最后,MSIE 中文档并不是从 0,0 开始,而是通常有一个小的边框(通常是 2 象素),边框的大小定义在 document.body.clientLeft 和 clientTop 中,我们也把这些加进去。

很幸运,我们现在已经用 mousePosition 函数解决了坐标问题,不需为此费心了。
下面是完整的事例,将其保存为HTML即可运行:

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


上一篇: JavaScript获取鼠标坐标的函数(兼容IE、FireFox、Chrome)
下一篇: Asp版的escape和unescape函数
文章来自: 本站原创
引用通告: 查看所有引用 | 我要引用此文章
Tags: javascript
相关日志:
评论: 1 | 引用: 0 | 查看次数: 2232
L360管线管[2012-05-23 12:29 AM | 访问 http://www.022xhrt.com | | 218.86.103.26 | del | 回复回复]
沙发
是要好好学习下了
发表评论
昵 称:
密 码: 游客发言不需要密码.
邮 箱: 邮件地址支持Gravatar头像,邮箱地址不会公开.
网 址: 输入网址便于回访.
内 容:
验证码:
选 项:
虽然发表评论不用注册,但是为了保护您的发言权,建议您注册帐号.
字数限制 1000 字 | UBB代码 开启 | [img]标签 关闭

 广告位

↑返回顶部↑