微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

js 获取元素在页面上的偏移量的方法汇总

使用js制作效果时,我们常常要获取某个元素在页面上的偏移量(例如tip提示功能)。而获取偏移量可以直接获取相对于document的偏移量,也可以获取相对与视口的偏移量(viewpoint)加上页面滚动量(scroll)获得。

1.获取相对与document的偏移量

rush:js;"> function getoffsetSum(ele){ var top= 0,left=0; while(ele){ top+=ele.offsetTop; left+=ele.offsetLeft; ele=ele.offsetParent; } return { top:top,left:left } }

通过向上迭代offsetParent,可以计算出相对于document的偏移量,也就是相对与页面的偏移量。

方法的问题:

1)对于使用表格和内嵌框架布局的页面,由于不同浏览器实现元素方式的差异,得到的结果就不精确了。

2)每次都需要一级一级向上查找offsetParent,效率太低。

2.获取相对与视口的偏移量(viewpoint)加上页面的滚动量(scroll)

rush:js;"> function getoffsetRect(ele){ var Box=ele.getBoundingClientRect(); var body=document.body,docElem=document.documentElement; //获取页面的scrollTop,scrollLeft(兼容性写法) var scrollTop=window.pageYOffset||docElem.scrollTop||body.scrollTop,scrollLeft=window.pageXOffset||docElem.scrollLeft||body.scrollLeft; var clientTop=docElem.clientTop||body.clientTop,clientLeft=docElem.clientLeft||body.clientLeft; var top=Box.top+scrollTop-clientTop,left=Box.left+scrollLeft-clientLeft; return { //Math.round 兼容火狐浏览器bug top:Math.round(top),left:Math.round(left) } }

方法直接通过getBoundingClientRect()方法获得相对于视口的偏移量,加上页面的滚动量,减去clientTop,clientLeft (IE8及更低版本浏览器将(2,2)作为起点坐标,所以要将值减去起点坐标,其他浏览器都是已(0,0)作为起点坐标)。

getBoundingClientRect()方法支持IE,ff3+,safari4+,Orear9,5,Chrome.

3.兼容性写法

rush:js;"> //获取元素相对于页面的偏移 function getoffset(ele){ if(ele.getBoundingClientRect){ return getoffsetRect(ele); }else{ return getoffsetSum(ele); } }

对于支持getBoundingClientRect()方法的浏览器使用getoffsetRect()方法不支持的则使用getoffsetSum()方法

以上所述就是本文的全部内容了,希望能够对大家学习javascript有是帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐