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 相关文章推荐
javascript高亮效果的二种实现方法
Sep 14 Javascript
javascript-简单的日历实现及Date对象语法介绍(附图)
May 30 Javascript
js网页右下角提示框实例
Oct 14 Javascript
innerHTML中标签可以换行的方法汇总
Aug 14 Javascript
JS组件Bootstrap Table布局详解
May 27 Javascript
jquery 删除节点 添加节点 找兄弟节点的简单实现
Dec 07 Javascript
jQuery动态添加.active 实现导航效果代码思路详解
Aug 29 jQuery
vue使用vue-i18n实现国际化的实现代码
Apr 08 Javascript
webuploader实现上传图片到服务器功能
Aug 16 Javascript
浅谈Webpack多页应用HMR卡住问题
Apr 24 Javascript
Vue CLI3基础学习之pages构建多页应用
Jun 02 Javascript
微信小程序国际化探索实现(附源码地址)
May 20 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 mysql与mysqli事务使用说明 分享
2013/08/17 PHP
PHP中Session引起的脚本阻塞问题解决办法
2014/04/08 PHP
实例讲解YII2中多表关联的使用方法
2017/07/21 PHP
php 可变函数使用小结
2018/06/12 PHP
thinkPHP框架实现多表查询的方法
2018/06/14 PHP
JS Jquery 遍历,筛选页面元素 自动完成(实现代码)
2013/07/08 Javascript
javascript 弹出的窗口返回值给父窗口具体实现
2013/11/23 Javascript
Vue.js 父子组件通讯开发实例
2016/09/06 Javascript
DropDownList控件绑定数据源的三种方法
2016/12/24 Javascript
vue实现动态数据绑定
2017/04/28 Javascript
easyui combogrid实现本地模糊搜索过滤多列
2017/05/13 Javascript
React学习之JSX与react事件实例分析
2020/01/06 Javascript
在vue项目中引用Antv G2,以饼图为例讲解
2020/10/28 Javascript
8个非常实用的Vue自定义指令
2020/12/15 Vue.js
对于Python编程中一些重用与缩减的建议
2015/04/14 Python
Python字符和字符值(ASCII或Unicode码值)转换方法
2015/05/21 Python
python计算文本文件行数的方法
2015/07/06 Python
Python3中使用urllib的方法详解(header,代理,超时,认证,异常处理)
2016/09/21 Python
python的文件操作方法汇总
2017/11/10 Python
对PyTorch torch.stack的实例讲解
2018/07/30 Python
Django CSRF跨站请求伪造防护过程解析
2019/07/31 Python
python 两种方法修改文件的创建时间、修改时间、访问时间
2020/09/26 Python
浅谈Python xlwings 读取Excel文件的正确姿势
2021/02/26 Python
css3 transform 3d 使用css3创建动态3d立方体(html5实践)
2013/01/06 HTML / CSS
澳洲健康食品网上商店:Aussie Health Products
2018/06/15 全球购物
乌克兰移动电子产品和相关配件的在线商店:iTMag
2020/03/16 全球购物
学生会主席演讲稿
2014/04/25 职场文书
校园安全标语
2014/06/07 职场文书
低碳日宣传活动总结
2014/07/09 职场文书
观后感格式
2015/06/19 职场文书
军训结束新闻稿
2015/07/17 职场文书
《假如》教学反思
2016/02/17 职场文书
详解PHP设计模式之依赖注入模式
2021/05/25 PHP
「玫瑰之王的葬礼」舞台剧主视觉图公开
2022/03/21 日漫
golang操作rocketmq的示例代码
2022/04/06 Golang
使用Python拟合函数曲线
2022/04/14 Python