原生js获取鼠标坐标方法全面讲解:clientX/Y,pageX/Y,offsetX/Y,layerX/Y,screenX/Y
2016-05-27 09:14
736 查看
关于js鼠标事件综合各大浏览器能获取到坐标的属性总共以下五种
event.clientX/Yevent.pageX/Y
event.offsetX/Y
event.layerX/Y
event.screenX/Y
clientX/Y:
clientX/Y获取到的是触发点相对浏览器可视区域左上角距离,不随页面滚动而改变兼容性:所有浏览器均支持
pageX/Y:
pageX/Y获取到的是触发点相对文档区域左上角距离,会随着页面滚动而改变设置<body style="width:2000px;height:200px;">让页面滚动,发现clientX与pageX的值不一样
兼容性:除IE6/7/8不支持外,其余浏览器均支持
offsetX/Y:
offsetX/Y获取到是触发点相对被触发dom的左上角距离,不过左上角基准点在不同浏览器中有区别,其中在IE中以内容区左上角为基准点不包括边框,如果触发点在边框上会返回负值,而chrome中以边框左上角为基准点。兼容性:IE所有版本,chrome,Safari均完美支持,Firefox不支持
layerX/Y:
layerX/Y获取到的是触发点相对被触发dom左上角的距离,数值与offsetX/Y相同,这个变量就是firefox用来替代offsetX/Y的,基准点为边框左上角,但是有个条件就是,被触发的dom需要设置为position:relative或者position:absolute,否则会返回相对html文档区域左上角的距离兼容性:IE6/7/8不支持,opera不支持,IE9/10和Chrome、Safari均支持
screenX/Y:
screenX/Y获取到的是触发点相对显示器屏幕左上角的距离,不随页面滚动而改变兼容性:所有浏览器均支持
/*我测试的clientX ,pageX代码*/
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style> *{margin:0;padding:0;} #wrap{ margin:30px auto; width:500px; height:200px; border:1px solid #ccc; text-align: center; overflow: scroll; } #wrap p{ display: block; height:400px; } </style> </head> <body style="height:2000px; width:20000px"> <div id="wrap"> <p>测试pageX和clientX的区别</p> </div> <script> window.onload=function(){ var oDiv = document.getElementById('wrap'); oDiv.onclick = function(e){ e = e || window.event; console.log('e.clientX:'+e.clientX); console.log('e.pageX:'+e.pageX); } } </script> </body> </html>
相关文章推荐
- 基于JS实现密码框(password)中显示文字提示功能代码
- SSM框架下,Jsp页面提交请求及action获取值得问题
- js跨域问题浅析及解决方法优缺点对比
- 13个JavaScript图表(JS图表)图形绘制插件【转】
- 13个JavaScript图表(JS图表)图形绘制插件【转】
- 【DRP分销】--- JSP的四个常用对象的作用域
- javascript笔记:函数的定义与调用
- 用JS获取地址栏参数的方法
- java和javaScript区别简单理解
- [RxJS] Transformation operator: scan
- JSP系列:(4)JSP进阶-EL表达式和JSP标签
- Phaser.js音频资源处理篇
- Phaser.js事件系统及用户交互篇
- 理清JavaScript正则表达式--上篇
- Convention插件的使用(会涉及content目录,jsp必须放入这个下面才能映射成功基于注解的配置)
- javascript的变量声明和函数声明提升
- js通过location.search来获取页面传来的参数
- JS复制内容到剪切板
- ZeroClipboard.js复制内容到剪贴板(跨浏览器)
- JS 上传图片先预览