源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2022-01-30 08:28 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:JavaScript与JQUERY获取元素的宽、高和位置
[b]javascript中[/b] 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;
//在窗口的位置+文档滚动掉的尺寸

为了跨浏览器兼容,文档卷掉的长度请使用如下方式: [code]varscrollTop= document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;[/code] [b]jQuery中[/b] 1.鼠标相对于页面的位置 [code]event.pageX/event.pageY:[/code]鼠标相对于页面左/上边缘的距离。 2.元素的位置偏移量 [code]offset():[/code]返回包含top和left两个属性的对象,相对于document文档的坐标。 [code]position():[/code]返回包含top和left两个属性的对象,相对于最近的已定位的包含元素的位置。若无,则相对于document。只对可见元素有效,注意ele{visibility:hidden}也属于可见元素。 3.元素的宽高 [code]width()/height():[/code]获得或设置元素【内容】的宽/高;若元素的display:none,其值为0。 [code]innerWidth()/innerHeight():[/code]获得包括内边距(padding)的元素宽度/高度,不包括边框; [code]outerWidth()/outerHeight():[/code]获得包括内边距(padding)和边框(border)的元素宽度/高度; [code]outerWidth(true)/outerHeight(true):[/code]获得整个元素的宽度/高度,包括外边距、边框、内边距和内容; [img]http://files.jb51.net/file_images/article/201702/2017022616370319.jpg[/img] 注意: 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>声明。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部