取得非绝对定位的元素的位置

关于offsetTop、offsetLeft、offsetWidth、offsetHeight的说明


最近群里有好群民在问关于offsetTop、offsetLeft、offsetWidth、offsetHeight等的意思及其用法,现简单总结如下:

假设 obj 为某个 HTML 控件。

obj.offsetTop :     指 obj 距离上方或上层控件的位置,整型,单位像素。

obj.offsetLeft :      指 obj 距离左方或上层控件的位置,整型,单位像素。

obj.offsetWidth  :  指 obj 控件自身的宽度,整型,单位像素。

obj.offsetHeight  :  指 obj 控件自身的高度,整型,单位像素。

现对上面提到的“上方或上层”与“左方或上层”控件作个说明。

例如:
<div id="tool">
     <input type="button" value="提交">
     <input type="button" value="重置">
</div>

“提交”按钮的 offsetTop 指“提交”按钮距“tool”层上边框的距离,因为距其上边最近的是 “tool” 层的上边框。
“重置”按钮的 offsetTop 指“重置”按钮距“tool”层上边框的距离,因为距其上边最近的是 “tool” 层的上边框。

“提交”按钮的 offsetLeft 指“提交”按钮距“tool”层左边框的距离,因为距其左边最近的是 “tool” 层的左边框。
“重置”按钮的 offsetLeft 指“重置”按钮距“提交”按钮右边框的距离,因为距其左边最近的是“提交”按钮的右边框


offsetParent:大多说offsetParent返回body

例子:
取得非绝对定位的元素的位置
var offset = function (o) {
//设置定位
    var $x = $y = 0;
    do { $x += o.offsetLeft, $y += o.offsetTop; }
    while (o = o.offsetParent);
    return { x : $x, y : $y };
};

var pos = offset(document.getElementById("元素id"));

alert(pos.x + ":" + pos.y);

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值