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

用 javascript 获取当页面上鼠标(光标)位置 – 示例

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

上面的代码我们在 怎么用 javascript 实现拖拽 中已经介绍过了,由于这个需求我们经常用到,所以我们将这段代码独立成一篇文章,供新手查询。

使用方式:

 document.onmousemove = mouseMove;function mouseMove(ev){ev = ev || window.event;var mousePos = mousePosition(ev);
}

关于代码的详细说明,原文中已经介绍,现转到此处:

我们首先要声明一个 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 函数解决了坐标问题,不需为此费心了。

转载于:https://www.cnblogs.com/toddzhang/p/3660060.html

用 javascript 获取当页面上鼠标(光标)位置相关推荐

  1. JS获取鼠标光标位置并在光标位置添加内容

    目标需求 获取鼠标光标位置,然后点击按钮或其他事件,在鼠标光标的位置插入需要的文字等 准备工具 contenteditable:contenteditable属性指定元素内容是否可编辑. window ...

  2. 获取手机屏幕上点击位置的坐标

    获取手机屏幕上点击位置的坐标 在手机开发者选项中,打开指针位置,可以在屏幕上方获取当前点击位置的坐标点(X,Y) P:1/1  X:553  Y:1851  Xv:0:0  Yv:0:0 Prs:1. ...

  3. vscode 修改快捷键 (回到上一处光标位置,下一处光标位置)

    前言 如题,很简单的一个问题,因而简单记录之.(之所以记录,是因为经历了小小的波折,觉得很有意思.) 环境 英文版 vscode Ubuntu 14.04 步骤 1)打开快捷键设置界面: File - ...

  4. 获取/设置input中的鼠标光标位置

    在我们实现字符分隔时,在一定的程度上增加了用户体验.但是使用replace时,不能控制光标的位置.如何设置呢? 步骤: 1.获取光标位置:var pos = this.selectionEnd;//获 ...

  5. 如何获取html页面上的按钮列表,如何从一个html页面获取单选按钮的值到另一个?...

    我尝试获取位于第一个html页面上的底部粘贴html代码的值.我有另一个html页面,应该用"onclick"按钮生成.更准确地说,代码应该在下一页中创建按钮.如何从一个html页 ...

  6. 自定义web页面上鼠标指针图标

    2019独角兽企业重金招聘Python工程师标准>>> 有时为了在特定区域显示特定的鼠标指针,需要设置 cursor属性,通常显示的是系统自带的鼠标指针,如何修改成为显示自定义图标的 ...

  7. 【语言-c#】显示设置-设置了缩放比列后,如何处理鼠标光标位置和屏幕大小

    问题描述 C#获取屏幕尺寸与位置与实际屏幕尺寸位置不一致 使用System.Windows.Forms.Screen.PrimaryScreen.Bounds获取的边界是 1536*864 而使用微信 ...

  8. webstrom 返回上一个光标位置

      看到一个方法,用ctrl+鼠标左键就可以转跳到这个方法,看完了想回到上一个光标的位置应该怎么操作.在百度没找到解决方法,其中的ctrl+alt+键盘方向左键,用了之后是整个电脑屏幕方向的改变,这是 ...

  9. java 获取jsp路径_java如何获取jsp页面上传的文件路径

    展开全部 楼主:用基础的java我不知道怎么实现.但是但62616964757a686964616fe78988e69d8331333335313131第三方jar包完全可以.而且上传文件方便. 代码 ...

最新文章

  1. python画图完整代码-Python科学画图代码分享
  2. Linux下安装Redis数据库
  3. 画图讲解SQL join 语句
  4. fread读取整个文件_qt如何实现大文件的加载和显示
  5. Storm-源码分析-Topology Submit-Client
  6. 开发工程师的职场人生路
  7. 怎么快速在计算机植入病毒,怎样给别人的电脑植入病毒
  8. 视频 | 直升机如何转弯,为什么能悬停在空中,它的飞行原理是什么?
  9. openbci脑电帽3d打印文件下载
  10. java web基础视频教程_java web开发入门视频教程
  11. Driver class 'org.gjt.mm.mysql.Driver' could not be found, make sure the 'MySQL' driver (jar file)
  12. Docker提交天池比赛代码流程(windows10环境下)
  13. 资料外泄:给系统管理者的警告
  14. 2021年美国大学生数学建模竞赛C题参考翻译
  15. 交叉编译ffmpeg:aac x264 x265
  16. 零成本的互联网赚钱项目,都是怎么做的?
  17. 一文搞懂大数据开发,大数据开发体系详解
  18. 嵌入式开发学习之--RCC(上)
  19. moviepy音视频剪辑:视频剪辑基类VideoClip的属性及方法详解
  20. CSS实现a标签去掉下划线以及点击不再有颜色变化

热门文章

  1. QPS相关的概念收集(吞吐量(TPS)、QPS、并发数、响应时间(RT))
  2. JAVA调用C语言写的SO文件
  3. 你知道Spring是怎么解析配置类的吗?
  4. Spring Validation 最佳实践及其实现原理,参数校验没那么简单!
  5. 面试官:kill -9 进程杀不掉,怎么办?
  6. Java 集合框架,看这篇真的够了!
  7. Spring Boot 项目 RedisTemplate 实现轻量级消息队列
  8. 小米自动化运维平台演进设计思路
  9. 微信中两大典型微服务案例
  10. 网络:XSS和HttpOnly