JS获取元素在页面的位置

JS获取元素的offsetTop,offsetLeft等属性
obj.clientWidth //获取元素的宽度(width+padding)
obj.clientHeight //元素的高度
obj.offsetLeft //元素相对于父元素的left
obj.offsetTop //元素相对于父元素的top
obj.offsetWidth //元素的宽度(width+padding+border)
obj.offsetHeight //元素的高度

//获取元素的纵坐标(相对于窗口)

  1. function getTop(e){
  2. var offset=e.offsetTop;
  3. if(e.offsetParent!=null) offset+=getTop(e.offsetParent);
  4. return offset;
  5. }

//获取元素的横坐标(相对于窗口)

  1. function getLeft(e){
  2. var offset=e.offsetLeft;
  3. if(e.offsetParent!=null) offset+=getLeft(e.offsetParent);
  4. return offset;
  5. }

上面的方法无疑影响性能,好在浏览器给我提供了相应的接口getBoundingClientRect,这个方法最早出现在IE浏览器中,后来的浏览器也跟着支持了这个方法,而且还更加完善,IE中只能获取到元素的left,top,bottom,right的属性,而后面的现代浏览器还能获取到元素的width和height.

ChromeFirefox (Gecko)Internet ExplorerOperaSafari
1.03.0 (1.9)4.0(Yes)4.0

这里要注意的是,bottom是元素底部相对于窗口顶部的距离,而不是像css里面position的bottom相对于窗口底部,同理,rihgt属性是元素最右边相对于窗口左边的距离。

  1. var box = document.getElementById("box");
  2. var pos = box.getBoundingClientRect();
  3. box.innerHTML = "top:"+pos.top +
  4. "left:"+pos.left +
  5. "bottom:"+pos.bottom +
  6. "right:"+pos.right +
  7. "width:"+pos.width +
  8. "height:"+pos.height
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值