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


Posted in Javascript onFebruary 26, 2017

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):获得整个元素的宽度/高度,包括外边距、边框、内边距和内容;

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

注意:

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 1.3.2以上版本中出现pareseerror错误的解决方法
Jan 11 Javascript
js函数返回多个返回值的示例代码
Nov 05 Javascript
js获取通过ajax返回的map型的JSONArray的方法
Jan 09 Javascript
纯js实现无限空间大小的本地存储
Jun 18 Javascript
jQuery+ajax简单实现文件上传的方法
Jun 03 Javascript
JS实现根据用户输入分钟进行倒计时功能
Nov 14 Javascript
JS设置CSS样式的方式汇总
Jan 21 Javascript
对象不支持indexOf属性或方法的解决方法(必看)
May 28 Javascript
详解Vue+axios+Node+express实现文件上传(用户头像上传)
Aug 10 Javascript
JS实现的类似微信聊天效果示例
Jan 29 Javascript
npm的lock机制解析
Jun 20 Javascript
layui radio单选限制下一个radio单选的实例
Sep 03 Javascript
JavaScript无阻塞加载和defer、async详解
Feb 26 #Javascript
浅谈JavaScript中的apply/call/bind和this的使用
Feb 26 #Javascript
JavaScript中Promise的使用详解
Feb 26 #Javascript
setTimeout函数的神奇使用
Feb 26 #Javascript
node.js入门学习之url模块
Feb 25 #Javascript
从零学习node.js之利用express搭建简易论坛(七)
Feb 25 #Javascript
从零学习node.js之express入门(六)
Feb 25 #Javascript
You might like
PHP网站安装程序制作的原理、步骤、注意事项和示例代码
2010/08/01 PHP
从手册去理解分析PHP session机制
2011/07/17 PHP
解析php通过cookies获取远程网页的指定代码
2013/06/25 PHP
CentOS安装php v8js教程
2015/02/26 PHP
浅谈PHP的反射API
2017/02/26 PHP
thinkphp分页集成实例
2017/07/24 PHP
锋利的jQuery jQuery中的DOM操作
2010/03/21 Javascript
JS数学函数Exp使用说明
2012/08/09 Javascript
jquery使用淘宝接口跨域查询手机号码归属地实例
2013/11/28 Javascript
jQuery简单实现网页选项卡特效
2014/11/24 Javascript
js下拉选择框与输入框联动实现添加选中值到输入框的方法
2015/08/17 Javascript
js变形金刚文字特效代码分享
2015/08/20 Javascript
基于jQuery实现表格的查看修改删除
2016/08/01 Javascript
JavaScript实现的CRC32函数示例
2016/11/23 Javascript
JS 中LocalStorage和SessionStorage的使用
2017/08/17 Javascript
Node.js readline模块与util模块的使用
2018/03/01 Javascript
Angular利用内容投射向组件输入ngForOf模板的方法
2018/03/05 Javascript
jQuery实现数字自动增加或者减少的动画效果示例
2018/12/11 jQuery
原生JavaScript实现的无缝滚动功能详解
2020/01/17 Javascript
Python for Informatics 第11章 正则表达式(一)
2016/04/21 Python
Python实现京东秒杀功能代码
2019/05/16 Python
Python基础之字符串操作常用函数集合
2020/02/09 Python
Python classmethod装饰器原理及用法解析
2020/10/17 Python
原生 JS+CSS+HTML 实现时序图的方法
2019/07/31 HTML / CSS
当当网官方旗舰店:中国图书销售夺金品牌
2018/04/02 全球购物
美国二手复古奢侈品包包购物网站:LXRandCo
2019/06/18 全球购物
Nicole Miller官方网站:纽约女装品牌
2019/09/14 全球购物
SheIn沙特阿拉伯:女装在线
2020/03/23 全球购物
大学生个人自我鉴定
2013/12/03 职场文书
服务宗旨标语
2014/07/01 职场文书
五好文明家庭事迹材料
2014/12/20 职场文书
2016年优秀共青团员事迹材料
2016/02/25 职场文书
Go语言切片前或中间插入项与内置copy()函数详解
2021/04/27 Golang
详解分布式系统中如何用python实现Paxos
2021/05/18 Python
Python中如何处理常见报错
2022/01/18 Python
Nginx如何配置多个服务域名解析共用80端口详解
2022/09/23 Servers