在IE和FF下能用的,获取按钮在网页中的绝对位置
转自:http://elf8848.javaeye.com/blog/227557
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>获取控件在网页中的绝对位置</title>
</head>
<body>
<div>如果您没有看到按钮,请往下拉到滚动条。</div>
<div style="height:500px;border:1px solid #6666CC;"> </div>
------------<input type="button" value="点我获取我的座标"
onclick="javascript:var pos = getCoordinate();alert('此按钮距页面左端 '+pos.x+' 像素,上端 '+pos.y+' 像素');" />
<script type="text/javascript" language="javascript">
function CPos(x, y)
{
this.x = x;
this.y = y;
}
// 取得事件(通用)
function $EVENTObject()
{
if(window.event) return window.event;
var f=$EVENTObject.caller;
while(f!=null)
{
var e = f.arguments[0];
if(e && (e.constructor==MouseEvent||e.constructor==Event||e.constructor==KeyboardEvent)) return e;
ff=f.caller;
}
}
//取得触发本事件的元素(通用)
function getElement()
{
var _enent=$EVENTObject();
if(window.event)
{
return _enent.srcElement; //是IE
}else{
return _enent.target; //是FF
}
}
//取得 调用本方法的按钮 距离页面最上端和最左端的位置
function getCoordinate()
{
var target =getElement();
var pos = new CPos(target.offsetLeft, target.offsetTop);
var targettarget = target.offsetParent;
while (target)
{
pos.x += target.offsetLeft;
pos.y += target.offsetTop;
targettarget = target.offsetParent
}
return pos;
}
</script>
</body>
</html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>获取控件在网页中的绝对位置</title>
</head>
<body>
<div>如果您没有看到按钮,请往下拉到滚动条。</div>
<div style="height:500px;border:1px solid #6666CC;"> </div>
------------<input type="button" value="点我获取我的座标"
onclick="javascript:var pos = getCoordinate();alert('此按钮距页面左端 '+pos.x+' 像素,上端 '+pos.y+' 像素');" />
<script type="text/javascript" language="javascript">
function CPos(x, y)
{
this.x = x;
this.y = y;
}
// 取得事件(通用)
function $EVENTObject()
{
if(window.event) return window.event;
var f=$EVENTObject.caller;
while(f!=null)
{
var e = f.arguments[0];
if(e && (e.constructor==MouseEvent||e.constructor==Event||e.constructor==KeyboardEvent)) return e;
ff=f.caller;
}
}
//取得触发本事件的元素(通用)
function getElement()
{
var _enent=$EVENTObject();
if(window.event)
{
return _enent.srcElement; //是IE
}else{
return _enent.target; //是FF
}
}
//取得 调用本方法的按钮 距离页面最上端和最左端的位置
function getCoordinate()
{
var target =getElement();
var pos = new CPos(target.offsetLeft, target.offsetTop);
var targettarget = target.offsetParent;
while (target)
{
pos.x += target.offsetLeft;
pos.y += target.offsetTop;
targettarget = target.offsetParent
}
return pos;
}
</script>
</body>
</html>
转自:http://elf8848.javaeye.com/blog/227557
分类:
06~javascript
, 06~js dom
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)