复制代码代码如下:
<CABEÇA>
<TITLE> JS获取DIV相对坐标</TITLE>
<script type="text/javascript"><!--
função getX(obj){
var parObj=obj;
var esquerda=obj.offsetLeft;
enquanto(parObj=parObj.offsetParent){
esquerda+=parObj.offsetLeft;
}
volte para a esquerda;
}
função obterY(obj){
var parObj=obj;
var top=obj.offsetTop;
while(parObj = parObj.offsetParent){
topo+=parObj.offsetTop;
}
retornar ao topo;
}
função DisplayCoord(evento){
var topo,esquerda,oDiv;
oDiv=document.getElementById("demonstração");
topo=getY(oDiv);
esquerda=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="margem:40px;" mce_style="margem: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(evento)">
我是DIV,经测试,有2PX的误差...
</div>
当前鼠标坐标为:
X:<span id="mp_x"></span>
S:<span id="mp_y"></span>
</body>
</BODY>
</HTML>
如果不对,可以试试将
documento.documentElement.scrollLeft
替换成
documento.body.scrollLeft