JavaScript与JQUERY获取元素的宽、高和位置

 更新时间:2017年02月26日 16:52:15   投稿:hebedich  
文章给大家汇总整理了JavaScript以及jQuery获取元素高宽和位置等信息的方法,非常的全面,小伙伴们可以记录下以便查看

javascript中

ele.getBoundingClientRect():获取一个元素相对于浏览器视口的的坐标(无论父元素定位与否),返回一个Object对象,该对象有6个属性:top/left/right/bottom/width/height。几乎所有浏览器都支持该方法。jQuery中没有直接的方法,需要用$(ele).offset().top-$(document).scrollTop()计算得到。

注意:right是指元素右边界距窗口最左边的距离,bottom是指元素下边界距窗口最上面的距离。

pageYOffset 属性是scrollY属性的别名,设置或返回文档在垂直方向滚动的像素值。window.pageYOffset == window.scrollY;前者浏览器兼容性更好。

所以获取元素在页面文档中的位置:

var X= ele.getBoundingClientRect().left+scrollTop;

var Y =ele.getBoundingClientRect().top+scrollTop;
//在窗口的位置+文档滚动掉的尺寸

为了跨浏览器兼容,文档卷掉的长度请使用如下方式:

varscrollTop= document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;

jQuery中

1.鼠标相对于页面的位置

event.pageX/event.pageY:鼠标相对于页面左/上边缘的距离。

2.元素的位置偏移量

offset():返回包含top和left两个属性的对象,相对于document文档的坐标。

position():返回包含top和left两个属性的对象,相对于最近的已定位的包含元素的位置。若无,则相对于document。只对可见元素有效,注意ele{visibility:hidden}也属于可见元素。

3.元素的宽高

width()/height():获得或设置元素【内容】的宽/高;若元素的display:none,其值为0。

innerWidth()/innerHeight():获得包括内边距(padding)的元素宽度/高度,不包括边框;

outerWidth()/outerHeight():获得包括内边距(padding)和边框(border)的元素宽度/高度;

outerWidth(true)/outerHeight(true):获得整个元素的宽度/高度,包括外边距、边框、内边距和内容;

注意:

1)ele.css("height"):返回带有完整单位的字符串(例如400px),若运算需要parseInt转换。ele.height():返回一个没有单位的number数值(例如400)。

2)height()总是返回内容宽度,不管CSS box-sizing属性值。若CSS box-sizing为border-box,将造成这个函数改变这个容器的outerHeight,而不仅是原来的内容高度。

4.浏览器相关宽高

$(window).height():获取浏览器可视窗口的高度;

$(document).height():获取整个网页文档的高度;当网页高度不足浏览器窗口时,返回的是$(window).height()。

$(document).scrollTop():document元素相对document元素对应的滚动条顶部的垂直偏移量,可获取已滚动的距离或设置将要滚动的距离。

即:当网页滚动条拉到最低端时,$(document).height() == $(window).height() + $(window).scrollTop()。

注意:不建议使用$("html").height()、$("body").height()这样的方法获取高度,原因有:

$("body").height():body可能会有边框,获取的高度会比$(document).height()小;

$("html").height():在不同的浏览器上获取的高度会有差异,浏览器不兼容。

$(window).height()若返回的不是浏览器窗口的高度,可能是网页没有加上<!DOCTYPE>声明。

相关文章

  • jquery ajax同步异步的执行最终解决方案

    jquery ajax同步异步的执行最终解决方案

    添加async:false.即修改为同步了,什么意思?按同事解释就是,这是等这个ajax有了返回值后才会执行下面的js一语道破天机,怪不得以前很多ajax调用里面的赋值都不起作用
    2013-04-04
  • jQuery轮播图效果精简版完整示例

    jQuery轮播图效果精简版完整示例

    这篇文章主要介绍了jQuery轮播图效果精简版,结合完整实例形式分析了jQuery响应鼠标事件及针对页面元素的遍历操作相关技巧,需要的朋友可以参考下
    2016-09-09
  • 用jquery存取照片的具体实现方法

    用jquery存取照片的具体实现方法

    这篇文章介绍了用jquery存取照片的具体实现方法,需要的朋友可以参考一下
    2013-06-06
  • jQuery EasyUI 入门必看

    jQuery EasyUI 入门必看

    下面小编就为大家带来一篇jQuery EasyUI 入门必看。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • juqery 学习之五 文档处理 包裹、替换、删除、复制

    juqery 学习之五 文档处理 包裹、替换、删除、复制

    这个函数的原理是检查提供的第一个元素(它是由所提供的HTML标记代码动态生成的),并在它的代码结构中找到最上层的祖先元素--这个祖先元素就是包裹元素。
    2011-02-02
  • jQuery实现简单弹幕效果

    jQuery实现简单弹幕效果

    这篇文章主要为大家详细介绍了jQuery实现简单弹幕效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • Jquery 方块随着鼠标所在的区域而放大

    Jquery 方块随着鼠标所在的区域而放大

    下面都是默认一样大小的方块,当鼠标放到你想要放的位置,则当前位置的方块则放大。
    2010-05-05
  • 10分钟学会写Jquery插件实例教程

    10分钟学会写Jquery插件实例教程

    这篇文章主要介绍了10分钟学会写Jquery插件,通过一个实例分两步完成一个简单的插件,非常实用,需要的朋友可以参考下
    2014-09-09
  • jQuery+html5+css3实现圆角无刷新表单带输入验证功能代码

    jQuery+html5+css3实现圆角无刷新表单带输入验证功能代码

    这篇文章主要介绍了jQuery+html5+css3实现圆角无刷新表单带输入验证功能代码,加入了html5与css3技术,使得整个表单效果更加唯美华丽,需要的朋友可以参考下
    2015-08-08
  • jQuery事件注册的实现示范

    jQuery事件注册的实现示范

    jQuery为我们提供了方便的事件注册机制,它的优点,操作简单,且不用担心事件覆盖等问题。缺点,普通的事件注册不能做事件委托,且无法实现事件解绑,需要借助其他方法
    2022-07-07

最新评论