获取鼠标在div中的相对位置的实现代码
2015-07-11 13:28
585 查看
复制代码 代码如下:
<HEAD>
<TITLE> JS获取DIV相对坐标</TITLE>
<script type="text/javascript"><!--
function getX(obj){
var parObj=obj;
var left=obj.offsetLeft;
while(parObj=parObj.offsetParent){
left+=parObj.offsetLeft;
}
return left;
}
function getY(obj){
var parObj=obj;
var top=obj.offsetTop;
while(parObj = parObj.offsetParent){
top+=parObj.offsetTop;
}
return top;
}
function DisplayCoord(event){
var top,left,oDiv;
oDiv=document.getElementById("demo");
top=getY(oDiv);
left=getX(oDiv);
document.getElementById("mp_x").innerHTML = (event.clientX-left+document.documentElement.scrollLeft) -2+"px";
document.getElementById("mp_y").innerHTML = (event.clientY-top+document.documentElement.scrollTop) -2+"px";
}
// --></script>
</HEAD>
<BODY style="margin:40px;" mce_style="margin:40px;">
<div style="background-color:#000000;color:#0011FF;width:300px;height:300px;position:absolute;top:80px;left:90px;margin:0px; border:0px;" id="demo" onmousemove="DisplayCoord(event)">
我是DIV,经测试,有2PX的误差...
</div>
当前鼠标坐标为:
X:<span id="mp_x"></span>
Y:<span id="mp_y"></span>
</body>
</BODY>
</HTML>
如果不对,可以试试将
document.documentElement.scrollLeft
替换成
document.body.scrollLeft
<HEAD>
<TITLE> JS获取DIV相对坐标</TITLE>
<script type="text/javascript"><!--
function getX(obj){
var parObj=obj;
var left=obj.offsetLeft;
while(parObj=parObj.offsetParent){
left+=parObj.offsetLeft;
}
return left;
}
function getY(obj){
var parObj=obj;
var top=obj.offsetTop;
while(parObj = parObj.offsetParent){
top+=parObj.offsetTop;
}
return top;
}
function DisplayCoord(event){
var top,left,oDiv;
oDiv=document.getElementById("demo");
top=getY(oDiv);
left=getX(oDiv);
document.getElementById("mp_x").innerHTML = (event.clientX-left+document.documentElement.scrollLeft) -2+"px";
document.getElementById("mp_y").innerHTML = (event.clientY-top+document.documentElement.scrollTop) -2+"px";
}
// --></script>
</HEAD>
<BODY style="margin:40px;" mce_style="margin:40px;">
<div style="background-color:#000000;color:#0011FF;width:300px;height:300px;position:absolute;top:80px;left:90px;margin:0px; border:0px;" id="demo" onmousemove="DisplayCoord(event)">
我是DIV,经测试,有2PX的误差...
</div>
当前鼠标坐标为:
X:<span id="mp_x"></span>
Y:<span id="mp_y"></span>
</body>
</BODY>
</HTML>
如果不对,可以试试将
document.documentElement.scrollLeft
替换成
document.body.scrollLeft
相关文章推荐
- C语言中给数组赋随机值
- Spring学习(23)--- AOP之Introductions应用
- 自定义Log4cpp的日志输出格式
- 套接字编程
- Ruby学习
- C#简单循环
- One or more constraints have not been satisfied.(SAPUI5+Eclipse)
- chapter17test2
- string类和智能指针(简洁版)和shareptr简洁版代码实现
- PHP:插入排序法
- PHP学习笔记之使用GD库制作验证码(一)
- matlab中 hold on 与hold off的用法
- ARM的QT phonon 的移植
- Ubuntu下 JDK环境变量的配置
- 【原创】Matlab中plot函数全功能解析
- C++ STL之vector
- Java中间Map List Set和其他收藏品
- C++/CLR 中的多线程使用方法
- 《Spring技术内幕》笔记-第三章 Spring AOP的实现
- vc++下 asci函数与unicode对照