鼠标事件的screenY,pageY,clientY,layerY,offsetY属性详解


Posted in Javascript onMarch 12, 2015

鼠标事件的screenY,pageY,clientY,layerY,offsetY属性详解

screenY

         鼠标相对于显示器屏幕左上角的偏移

pageY

         鼠标相对于页面左上角的偏移 (其值不会受滚动条的影响)

         IE9之下并不支持这个属性

         但是可以写点代码计算出来。 jQuery中的实现:

 // Calculate pageX/Y if missing and clientX/Y available

 if ( event.pageX == null && original.clientX != null ) {

     eventDoc = event.target.ownerDocument || document;

     doc = eventDoc.documentElement;

     body = eventDoc.body;

     event.pageX = original.clientX + ( doc && doc.scrollLeft || body && body.scrollLeft || 0 ) - ( doc && doc.clientLeft||body&&body.clientLeft || 0 );

     event.pageY = original.clientY + ( doc && doc.scrollTop  || body && body.scrollTop  || 0 ) - ( doc && doc.clientTop  || body && body.clientTop  || 0 );

 }   

简单点实现就是。 

鼠标相对于浏览器视口的偏移加上文档的滚动条隐藏的高度减去文档的clientTop.

var pageY = event.clientY +document.documentElement. scrollTop-document.documentElement.clientTop

为何要减去document.documentElement.clientTop

这是IE8之下浏览器特有的文档的偏移,即使设置html,body的padding和margin为0也不会影响其值。

在iE7下测试,得到                              

 document.documentElement.clientTop --> 2px  document.documentElement.clientLeft --> 2px

 document.bocy.clientTop --> 0px  document.body.clientLeft --> 0px

clientY

         鼠标相对于浏览器视口左上角的偏移

         注意clientY和pageY的区别,clientY在页面无滚动条的情况下值等同于pageY

----------------------------------分割-----------------------------------------------

layerY

         如果元素的position样式不是默认的static,我们说这个元素具有定位属性。

         在当前触发鼠标事件的元素和它的祖先元素中找到最近的具有定位属性的元素,计算鼠标与其的偏移值,以找到元素的border的左上角的外交点作为相对点。如果找不到具有定位属性的元素,那么就相对于当前页面计算偏移,此时等同于pageY。

鼠标事件的screenY,pageY,clientY,layerY,offsetY属性详解

         IE9之下并不支持这个属性,但是可以用其特有的offsetY替换

offsetY  

 

  IE专有的属性

         offsetY和layerY的不同在于,前者的在计算偏移值时,相对于元素的border左上角的内交点,因此当鼠标位于元素的border上时,偏移值是一个负值。 另外offsetY并不在乎触发事件的元素是否有定位属性,它总是相对于触发事件的元素来计算偏移值。

鼠标事件的screenY,pageY,clientY,layerY,offsetY属性详解

   鉴于layerY和offsetY的不同,要兼容的使用二者要注意

        

1.触发事件的元素一定要设置定位属性。

       

2.在元素具有上边框border-top的情况下, layerY比offsetY的值多一个border-top的宽度值。

 //这里的element.borderTopWidth必须是实际计算出的元素的上边框宽度。

 var borderTopWidth =  window.getComputedStyle ? window.getComputedStyle(element,null).borderTopWidth: element.currentStyle.borderTopWidth; 

 var offsetY = event.offsetY||(event.layerY + borderTopWidth);

通过layerY和offsetY属性,可以很方便的计算鼠标相对于绑定鼠标事件元素的偏移,这在某些时候非常有用。   

这里详细说了鼠标竖直方向的偏移属性,水平方向的偏移类似,不再讨论。

以上就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
JavaScript基本概念初级讲解论坛贴的学习记录
Feb 22 Javascript
jquery 批量上传图片实现代码
Jan 28 Javascript
javascript Window及document对象详细整理
Jan 12 Javascript
jQuery使用之处理页面元素用法实例
Jan 19 Javascript
JavaScript、tab切换完整版(自动切换、鼠标移入停止、移开运行)
Jan 05 Javascript
利用Jquery队列实现根据输入数量显示的动画
Sep 01 Javascript
jquery实现tab键进行选择后enter键触发click行为
Mar 29 jQuery
angularJs中datatable实现代码
Jun 03 Javascript
原生javascript单例模式的应用实例分析
Feb 23 Javascript
javascript设计模式 ? 适配器模式原理与应用实例分析
Apr 13 Javascript
小程序实现录音功能
Sep 22 Javascript
原生JavaScript实现简单五子棋游戏
Jun 28 Javascript
JavaScript中return false的用法
Mar 12 #Javascript
JavaScript中神奇的call()方法
Mar 12 #Javascript
jquery实现无限分级横向导航菜单的方法
Mar 12 #Javascript
JavaScript中定义函数的三种方法
Mar 12 #Javascript
javascript实时显示北京时间的方法
Mar 12 #Javascript
jquery实现焦点图片随机切换效果的方法
Mar 12 #Javascript
JavaScript数据结构与算法之栈详解
Mar 12 #Javascript
You might like
PHP安全性漫谈
2012/06/28 PHP
PHP中UNIX时间戳和日期间的转换与计算实例
2014/11/19 PHP
PHP页面输出搜索后跳转下一页的处理方法
2016/09/30 PHP
laravel 实现划分admin和home 模块分组
2019/10/15 PHP
一个JavaScript继承的实现
2006/10/24 Javascript
javascript 树控件 比较好用
2009/06/11 Javascript
JS控制显示隐藏兼容问题(IE6、IE7、IE8)
2010/04/01 Javascript
js字符串转换成xml对象并使用技巧解读
2013/04/18 Javascript
Javascript玩转继承(一)
2014/05/08 Javascript
Javascript实现商品秒杀倒计时(时间与服务器时间同步)
2015/09/16 Javascript
JavaScript原生对象常用方法总结(推荐)
2016/05/13 Javascript
JS字符串false转boolean的方法(推荐)
2017/03/08 Javascript
浅谈JavaScript正则表达式-非捕获性分组
2017/03/08 Javascript
JavaScript标准对象_动力节点Java学院整理
2017/06/27 Javascript
微信小程序日历组件使用方法详解
2018/12/29 Javascript
Vue实现类似Spring官网图片滑动效果方法
2019/03/01 Javascript
利用Promise自定义一个GET请求的函数示例代码
2019/03/20 Javascript
教你30秒发布一个TypeScript包到NPM的方法步骤
2019/07/22 Javascript
javascript实现切割轮播效果
2019/11/28 Javascript
uni-app使用countdown插件实现倒计时
2020/11/01 Javascript
[06:40]2014DOTA2西雅图国际邀请赛 DK战队巡礼
2014/07/07 DOTA
pycharm 使用心得(一)安装和首次使用
2014/06/05 Python
Python使用django搭建web开发环境
2017/06/09 Python
浅谈Python用QQ邮箱发送邮件时授权码的问题
2018/01/29 Python
Python实现上下班抢个顺风单脚本
2018/02/07 Python
python构建深度神经网络(DNN)
2018/03/10 Python
浅析python,PyCharm,Anaconda三者之间的关系
2019/11/27 Python
Paradigit比利时电脑卖场:购买笔记本、电脑、平板和外围设备
2016/11/28 全球购物
Myprotein法国官网:欧洲第一运动营养品牌
2019/03/26 全球购物
建筑毕业生自我鉴定
2013/10/18 职场文书
自荐信的基本格式
2014/02/22 职场文书
专家推荐信模板
2014/05/09 职场文书
综合素质评价思想道德自我评价
2015/03/09 职场文书
详解缓存穿透击穿雪崩解决方案
2021/05/28 Redis
Spring Data JPA使用JPQL与原生SQL进行查询的操作
2021/06/15 Java/Android
Java实现简易的分词器功能
2021/06/15 Java/Android