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>声明。
# javascript
# 获取元素
# jquery
# 获取元素位置
# js jquery 获取某一元素到浏览器顶端的距离实现方法
# JS与jQuery实现子窗口获取父窗口元素值的方法
# 使用jquery/js获取iframe父子级、同级获取元素的方法
# JavaScript和jquery获取父级元素、子级元素、兄弟元素的方法
# js jquery获取当前元素的兄弟级 上一个 下一个元素
# Js与Jq 获取页面元素值的方法和差异对比
# js与jquery获取父级元素
# 子级元素
# 兄弟元素的实现方法
# js与jquery获取父元素
# 删除子元素的两种不同方法
# JS和JQUERY获取页面大小
# 滚动条位置
# 元素位置(示例代码)
# 原生JS与JQ获取元素的区别详解
# 相对于
# 文档
# 会有
# 鼠标
# 是指
# 滚动条
# 的是
# 偏移量
# 而不
# 请使用
# 仅是
# 会比
# 几乎所有
# 不包括
# 拉到
# 只对
# 若无
# 需要用
# 值为
# 不兼容
相关文章:
建站上市公司网站建设方案与SEO优化服务定制指南
如何用狗爹虚拟主机快速搭建网站?
建站VPS推荐:2025年高性能服务器配置指南
沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?
大连网站设计制作招聘信息,大连投诉网站有哪些?
专业网站建设制作报价,网页设计制作要考什么证?
如何在腾讯云免费申请建站?
在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?
重庆网站制作公司哪家好,重庆中考招生办官方网站?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
网站设计制作公司地址,网站建设比较好的公司都有哪些?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
python的本地网站制作,如何创建本地站点?
测试制作网站有哪些,测试性取向的权威测试或者网站?
大型企业网站制作流程,做网站需要注册公司吗?
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
如何快速搭建安全的FTP站点?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
XML的“混合内容”是什么 怎么用DTD或XSD定义
,制作一个手机app网站要多少钱?
如何在企业微信快速生成手机电脑官网?
C++时间戳转换成日期时间的步骤和示例代码
宝塔面板如何快速创建新站点?
如何选择高效响应式自助建站源码系统?
沈阳制作网站公司排名,沈阳装饰协会官方网站?
太原网站制作公司有哪些,网约车营运证查询官网?
如何注册花生壳免费域名并搭建个人网站?
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
c# 服务器GC和工作站GC的区别和设置
广德云建站网站建设方案与建站流程优化指南
如何选择PHP开源工具快速搭建网站?
专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?
网站制作说明怎么写,简述网页设计的流程并说明原因?
网站制作话术技巧,网站推广做的好怎么话术?
网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?
javascript基本数据类型及类型检测常用方法小结
建站主机是否属于云主机类型?
建站之星安装步骤有哪些常见问题?
为什么Go需要go mod文件_Go go mod文件作用说明
建站主机选虚拟主机还是云服务器更好?
做企业网站制作流程,企业网站制作基本流程有哪些?
专业商城网站制作公司有哪些,pi商城官网是哪个?
香港服务器如何优化才能显著提升网站加载速度?
如何选择高效便捷的WAP商城建站系统?
北京网站制作的公司有哪些,北京白云观官方网站?
制作农业网站的软件,比较好的农业网站推荐一下?
如何通过老薛主机一键快速建站?
C#如何在一个XML文件中查找并替换文本内容
*请认真填写需求信息,我们会在24小时内与您取得联系。