js获取鼠标位置实例详解


Posted in Javascript onDecember 09, 2015

本文实例讲述了js获取鼠标位置的方法。分享给大家供大家参考,具体如下:

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

Javascript代码如下:

<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>

使用方式:

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 中,我们也把这些加进去。

完成代码:

<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
   };
}
document.onmousemove = mouseMove;
function mouseMove(ev){
 ev = ev || window.event;
 var mousePos = mousePosition(ev);
   document.getElementByIdx('mouseXPosition').value = mousePos.x;
   document.getElementByIdx('mouseYPosition').value = mousePos.y;
}
</script>

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
js的逻辑运算符 ||
May 31 Javascript
js 如何实现对数据库的增删改查
Nov 23 Javascript
网页中可关闭的漂浮窗口实现可自行调节
Aug 20 Javascript
使用insertAfter()方法在现有元素后添加一个新元素
May 28 Javascript
Javascript学习笔记之 对象篇(三) : hasOwnProperty
Jun 24 Javascript
jquery渐隐渐显的图片幻灯闪烁切换实现方法
Feb 26 Javascript
js中函数声明与函数表达式
Jun 03 Javascript
解析JavaScript的ES6版本中的解构赋值
Jul 28 Javascript
基于JavaScript实现复选框的全选和取消全选
Feb 09 Javascript
angular中实现li或者某个元素点击变色的两种方法
Jul 27 Javascript
js + css实现标签内容切换功能(实例讲解)
Oct 09 Javascript
关于React动态加载路由处理的相关问题
Jan 07 Javascript
JavaScript常用基础知识强化学习
Dec 09 #Javascript
AngularJS实现元素显示和隐藏的几个案例
Dec 09 #Javascript
谈谈AngularJs中的隐藏和显示
Dec 09 #Javascript
jquery插件ajaxupload实现文件上传操作
Dec 09 #Javascript
js实现卡片式项目管理界面UI设计效果
Dec 08 #Javascript
javascript如何写热点图
Dec 08 #Javascript
jQuery基于ajax()使用serialize()提交form数据的方法
Dec 08 #Javascript
You might like
php登陆页的密码处理方式分享
2013/10/14 PHP
为百度UE编辑器上传图片添加水印功能
2015/04/16 PHP
php命令行(cli)下执行PHP脚本文件的相对路径的问题解决方法
2015/05/25 PHP
启用Csrf后POST数据时出现的400错误
2015/07/05 PHP
PHP+JQuery+Ajax实现分页方法详解
2016/08/06 PHP
mac系统下安装多个php并自由切换的方法详解
2017/04/21 PHP
ThinkPHP 5.x远程命令执行漏洞复现
2019/09/23 PHP
如何通过PHP实现Des加密算法代码实例
2020/05/09 PHP
Jquery获取元素的父容器对象示例代码
2014/02/10 Javascript
node.js中的fs.symlinkSync方法使用说明
2014/12/15 Javascript
JavaScript通过prototype给对象定义属性用法实例
2015/03/23 Javascript
jQuery 遍历函数详解
2015/07/05 Javascript
JavaScript实现的Tween算法及缓冲特效实例代码
2015/11/03 Javascript
JS模拟简易滚动条效果代码(附demo源码)
2016/04/05 Javascript
使用递归遍历对象获得value值的实现方法
2016/06/14 Javascript
jQuery的Cookie封装,与PHP交互的简单实现
2016/10/05 Javascript
Angularjs之filter过滤器(推荐)
2016/11/27 Javascript
JavaScript中利用构造器函数模拟类的方法
2017/02/16 Javascript
video.js使用改变ui过程
2017/03/05 Javascript
JavaScript反弹动画效果的实现代码
2017/07/13 Javascript
关于layui 实现点击按钮添加一行(方法渲染创建的table)
2019/09/29 Javascript
jquery实现点击左右按钮切换图片
2021/01/27 jQuery
Python常用的内置序列结构(列表、元组、字典)学习笔记
2016/07/08 Python
使用Python进行QQ批量登录的实例代码
2018/06/11 Python
Django Rest framework频率原理与限制
2019/07/26 Python
Python Des加密解密如何实现软件注册码机器码
2020/01/08 Python
结束运行python的方法
2020/06/16 Python
解决HTML5中的audio在手机端和微信端的不能自动播放问题
2019/11/04 HTML / CSS
幼儿园春游活动方案
2014/01/19 职场文书
《雨霖铃》教学反思
2014/02/22 职场文书
学校课外活动总结
2014/05/08 职场文书
保险公司开门红口号
2014/06/21 职场文书
ktv好的活动方案
2014/08/15 职场文书
晚自修旷课检讨书怎么写
2014/11/17 职场文书
小学生作文评语集锦
2014/12/25 职场文书
如何使用php生成zip压缩包
2021/04/21 PHP