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 相关文章推荐
jquery实现的鼠标下拉滚动置顶效果
Jul 24 Javascript
判断是否存在子节点的实现代码
May 18 Javascript
跨域请求的完美解决方法(JSONP, CORS)
Jun 12 Javascript
JavaScript如何实现跨域请求
Aug 05 Javascript
基于vue2实现上拉加载功能
Nov 28 Javascript
swiper自定义分页器使用方法详解
Sep 14 Javascript
react-native-video实现视频全屏播放的方法
Mar 19 Javascript
jQuery选择器之基本选择器用法实例分析
Feb 19 jQuery
vue动态绑定class的几种常用方式小结
May 21 Javascript
Swiper.js实现移动端元素左右滑动
Sep 08 Javascript
uni-app使用countdown插件实现倒计时
Nov 01 Javascript
vue实现水波涟漪效果的点击反馈指令
May 31 Vue.js
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
不用GD库生成当前时间的PNG格式图象的程序
2006/10/09 PHP
PHP 分页类(模仿google)-面试题目解答
2009/09/13 PHP
php daddslashes()和 saddslashes()有哪些区别分析
2012/10/26 PHP
php addslashes 利用递归实现使用反斜线引用字符串
2013/08/05 PHP
mcrypt启用 加密以及解密过程详细解析
2013/08/07 PHP
javascript跨域的方法汇总
2015/10/23 Javascript
JQuery控制DIV的选取实现方法
2016/09/18 Javascript
javascript中数组(Array)对象和字符串(String)对象的常用方法总结
2016/12/15 Javascript
jQuery无刷新上传之uploadify简单代码
2017/01/17 Javascript
js 函数式编程学习笔记
2017/03/25 Javascript
easyui-edatagrid.js实现回车键结束编辑功能的实例
2017/04/12 Javascript
详解vue项目打包步骤
2019/03/29 Javascript
微信小程序代码上传、审核发布小程序
2019/05/18 Javascript
Vue.js中该如何自己维护路由跳转记录
2019/05/19 Javascript
JS删除String里某个字符的方法
2021/01/06 Javascript
nodejs+koa2 实现模仿springMVC框架
2020/10/21 NodeJs
[01:13:08]2018DOTA2亚洲邀请赛4.6 淘汰赛 mineski vs LGD 第二场
2018/04/10 DOTA
python实现的解析crontab配置文件代码
2014/06/30 Python
python实现的文件夹清理程序分享
2014/11/22 Python
Python实现K折交叉验证法的方法步骤
2019/07/11 Python
Python中文分词库jieba,pkusegwg性能准确度比较
2020/02/11 Python
Django admin组件的使用
2020/10/24 Python
详解python中的异常和文件读写
2021/01/03 Python
纯css3实现思维导图样式示例
2018/11/01 HTML / CSS
"引用"与多态的关系
2013/02/01 面试题
北京振戎融通Java面试题
2015/09/03 面试题
法学专业毕业生自荐信范文
2013/12/18 职场文书
说明书格式及范文
2014/05/07 职场文书
中学教师暑期培训方案
2014/08/27 职场文书
2014年计划生育工作总结
2014/11/14 职场文书
内乡县衙导游词
2015/02/05 职场文书
2015年学生会干事工作总结
2015/04/09 职场文书
拾金不昧通报表扬范文
2015/05/05 职场文书
九年级历史教学反思
2016/02/19 职场文书
Django分页器的用法你都了解吗
2021/05/26 Python
MySQL自定义函数及触发器
2022/08/05 MySQL