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


Posted in Javascript onApril 13, 2015

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

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

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)

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.兼容性写法

//获取元素相对于页面的偏移
function getOffset(ele){
  if(ele.getBoundingClientRect){
    return getOffsetRect(ele);
  }else{
    return getOffsetSum(ele);
  }
}

对于支持getBoundingClientRect()方法的浏览器使用getOffsetRect()方法,不支持的则使用getOffsetSum()方法。

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

Javascript 相关文章推荐
直接生成打开窗口代码,不必下载
May 14 Javascript
表单类各种类型(文本框)失去焦点效果jquery代码
Apr 26 Javascript
简单时间提示DEMO从0开始一直进行计时
Nov 19 Javascript
JQuery勾选指定name的复选框集合并显示的方法
May 18 Javascript
javascript表单验证大全
Aug 12 Javascript
简介AngularJS中$http服务的用法
Feb 06 Javascript
BootstrapTable+KnockoutJS自定义T4模板快速生成增删改查页面
Aug 01 Javascript
Bootstrap 下拉多选框插件Bootstrap Multiselect
Jan 22 Javascript
深入理解Commonjs规范及Node模块实现
May 17 Javascript
JavaScript+CSS相册特效实例代码
Sep 07 Javascript
JavaScript实现左侧菜单效果
Dec 14 Javascript
jquery 实现拖动文件上传加载进度条功能
Mar 18 jQuery
javascript中scrollTop详解
Apr 13 #Javascript
jQuery实现的在线答题功能
Apr 12 #Javascript
jQuery插件bxSlider实现响应式焦点图
Apr 12 #Javascript
jQuery插件Skippr实现焦点图幻灯片特效
Apr 12 #Javascript
jQuery插件pagination实现分页特效
Apr 12 #Javascript
jQuery插件multiScroll实现全屏鼠标滚动切换页面特效
Apr 12 #Javascript
jQuery插件slicebox实现3D动画图片轮播切换特效
Apr 12 #Javascript
You might like
php在程序中将网页生成word文档并提供下载的代码
2012/10/09 PHP
PHP中include和require的区别实例分析
2017/05/07 PHP
PHP下载大文件失败并限制下载速度的实例代码
2019/05/10 PHP
JavaScript 学习笔记(十二) dom
2010/01/21 Javascript
jQuery模拟点击A标记示例参考
2014/04/17 Javascript
关于webuploader插件使用过程遇到的小问题
2016/11/07 Javascript
JS如何设置iOS中微信浏览器的title
2016/11/22 Javascript
javascript计算渐变颜色的实例
2017/09/22 Javascript
vue+node+webpack环境搭建教程
2017/11/05 Javascript
基于vue-cli 打包时抽离项目相关配置文件详解
2018/03/07 Javascript
浅谈vuex中store的命名空间
2019/11/08 Javascript
JavaScript实现滑块验证解锁
2021/01/07 Javascript
[15:57]教你分分钟做大人:斧王
2014/10/30 DOTA
[00:12]2018DOTA2亚洲邀请赛SOLO赛 MidOne是否中单第一人?
2018/04/05 DOTA
Python使用email模块对邮件进行编码和解码的实例教程
2016/07/01 Python
Python实现的爬虫功能代码
2017/06/24 Python
利用Python yagmail三行代码实现发送邮件
2018/05/11 Python
Python 确定多项式拟合/回归的阶数实例
2018/12/29 Python
PyQt Qt Designer工具的布局管理详解
2019/08/07 Python
python实现图像拼接功能
2020/03/23 Python
pyecharts动态轨迹图的实现示例
2020/04/17 Python
Python+OpenCV图像处理—— 色彩空间转换
2020/10/22 Python
CSS3 animation实现简易幻灯片轮播特效
2016/09/27 HTML / CSS
CSS3改变浏览器滚动条样式
2019/01/04 HTML / CSS
html5 桌面提醒:Notifycations应用介绍
2012/11/27 HTML / CSS
Booking.com亚太地区:Booking.com APAC
2020/02/07 全球购物
ShellScript面试题一则-ShellScript编程
2014/03/05 面试题
【魔兽争霸3重制版】原版画面与淬火MOD画面对比
2021/03/26 魔兽争霸
简历上的自我评价怎么写
2014/01/28 职场文书
挂牌仪式主持词
2014/03/20 职场文书
文体活动总结范文
2014/05/05 职场文书
党员自我对照检查材料
2014/08/19 职场文书
承诺函范文
2015/01/21 职场文书
2015年教师学期工作总结
2015/04/30 职场文书
教师节领导致辞
2015/07/29 职场文书
医院病假条范文
2015/08/17 职场文书