获取鼠标在div中的相对位置的实现代码
作者:互联网
2025-08-17
复制代码代码如下:
< 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
相关标签:
相关推荐
专题
+ 收藏
+ 收藏
+ 收藏
+ 收藏
+ 收藏
+ 收藏
最新数据
相关文章
vue3中静态提升和patchflag实现
你的 Vue 3 ref(),VuReact 会编译成什么样的 React?
你的 Vue 3 reactive(),VuReact 会编译成什么样的 React?
Vue3 转 React:组件透传 Attributes 与 useAttrs 使用详解|VuReact 实战
使用 VueUse 构建一个支持暂停/重置的 CountUp 组件
vue2中使用 AntV G6
前端视频媒体带声音自动播放方案最佳实践和教程
[前端]可折叠容器组件、信息展示卡片组件
Vue3 日历组件选型指南:五大主流方案深度解析
Vue3 代码编写规范 | 避坑指南+团队协作标准
AI精选
