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 相关文章推荐
wordpress之js库集合研究介绍
Aug 17 Javascript
JavaScript函数、方法、对象代码
Oct 29 Javascript
jQuery实现点击后标记当前菜单位置(背景高亮菜单)效果
Aug 22 Javascript
详解Angularjs在控制器(controller.js)中使用过滤器($filter)格式化日期/时间实例
Feb 17 Javascript
深入理解React高阶组件
Sep 28 Javascript
前端MVVM框架解析之双向绑定
Jan 24 Javascript
在 Angular-cli 中使用 simple-mock 实现前端开发 API Mock 接口数据模拟功能的方法
Nov 28 Javascript
express+vue+mongodb+session 实现注册登录功能
Dec 06 Javascript
详解服务端预渲染之Nuxt(介绍篇)
Apr 07 Javascript
vue使用微信JS-SDK实现分享功能
Aug 23 Javascript
layui点击弹框页面 表单请求的方法
Sep 21 Javascript
Vue实现PC端靠边悬浮球的代码
May 09 Javascript
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根据身份证号码计算年龄的实例代码
2014/01/18 PHP
php set_include_path函数设置 include_path 配置选项
2016/10/30 PHP
php实现的表单验证类完整示例
2019/08/13 PHP
一些常用的Javascript函数
2006/12/22 Javascript
基于jQuery实现左右div自适应高度完全相同的代码
2012/08/09 Javascript
js函数中onmousedown和onclick的区别和联系探讨
2013/05/19 Javascript
详解JavaScript逻辑Not运算符
2015/12/04 Javascript
jQuery实现的文字hover颜色渐变效果实例
2016/02/20 Javascript
javascirpt实现2个iframe之间传值的方法
2016/06/30 Javascript
bootstrap jquery dataTable 异步ajax刷新表格数据的实现方法
2017/02/10 Javascript
微信分享调用jssdk实例
2017/06/08 Javascript
ionic3 懒加载
2017/08/16 Javascript
JavaScript简单实现的仿微博留言功能示例
2019/01/17 Javascript
vue 使用post/get 下载导出文件操作
2020/08/07 Javascript
js+html+css实现手动轮播和自动轮播
2020/12/30 Javascript
[03:07]完美世界DOTA2联赛PWL DAY10 决赛集锦
2020/11/11 DOTA
python3实现跳一跳点击跳跃
2018/01/08 Python
python使用opencv驱动摄像头的方法
2018/08/03 Python
python与C、C++混编的四种方式(小结)
2019/07/15 Python
Python 内置变量和函数的查看及说明介绍
2019/12/25 Python
python中数字是否为可变类型
2020/07/08 Python
Kathmandu英国网站:新西兰户外运动品牌
2017/03/27 全球购物
在线学习西班牙语、法语或其他语言:Babbel.com
2018/02/07 全球购物
Java中有几种类型的流?JDK为每种类型的流提供了一些抽象类以供继承,请说出他们分别是哪些类?
2012/05/30 面试题
护理专业个人求职简历的自我评价
2013/10/13 职场文书
网络维护中文求职信
2014/01/03 职场文书
社区工作者思想汇报
2014/01/13 职场文书
家长给孩子的表扬信
2014/01/17 职场文书
财务人员的自我评价范文
2014/03/03 职场文书
共产党员公开承诺书
2014/03/25 职场文书
祖国在我心中演讲稿600字
2014/05/04 职场文书
汽车技术服务与贸易专业求职信
2014/07/20 职场文书
单位委托书怎么写
2014/09/21 职场文书
因身体原因离职的辞职信范文
2015/05/12 职场文书
使用jpa之动态插入与修改(重写save)
2021/11/23 Java/Android
JavaScript实现简单的音乐播放器
2022/08/14 Javascript