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 对象与DOM对象之两者相互间的转换
Apr 27 Javascript
javascript正则匹配汉字、数字、字母、下划线
Apr 10 Javascript
jQuery实现有动画淡出效果的二级折叠菜单代码
Oct 17 Javascript
轻松掌握JavaScript代理模式
Aug 26 Javascript
微信小程序 免费SSL证书https、TLS版本问题的解决办法
Dec 14 Javascript
AngularJS ng-repeat指令中使用track by子语句解决重复数据遍历错误问题
Jan 21 Javascript
将 vue 生成的 js 上传到七牛的实例
Jul 28 Javascript
当vue路由变化时,改变导航栏的样式方法
Aug 22 Javascript
angular4中*ngFor不能对返回来的对象进行循环的解决方法
Sep 12 Javascript
vue绑定事件后获取绑定事件中的this方法
Sep 15 Javascript
用Fundebug插件记录网络请求异常的方法
Feb 21 Javascript
javascript-hashchange事件和历史状态管理实例分析
Apr 18 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新手上路(七)
2006/10/09 PHP
php实现的简单压缩英文字符串的代码
2008/04/24 PHP
php不允许用户提交空表单(php空值判断)
2013/11/12 PHP
PHP进程同步代码实例
2015/02/12 PHP
Windows 下安装 swoole 图文教程(php)
2017/06/05 PHP
PHP实现找出有序数组中绝对值最小的数算法分析
2017/08/07 PHP
关于php unset对json_encode的影响详解
2018/11/14 PHP
使用js画图之画切线
2015/01/12 Javascript
详细分析使用AngularJS编程中提交表单的方式
2015/06/19 Javascript
超赞的动手创建JavaScript框架的详细教程
2015/06/30 Javascript
js实现文本框宽度自适应文本宽度的方法
2015/08/13 Javascript
jquery实现邮箱自动填充提示功能
2015/11/17 Javascript
js发送短信倒计时的简单实现方法
2016/09/08 Javascript
JS判断指定dom元素是否在屏幕内的方法实例
2017/01/23 Javascript
BootStrap表单时间选择器详解
2017/05/09 Javascript
自定义类似于jQuery UI Selectable 的Vue指令v-selectable
2017/08/23 jQuery
微信小程序实现YDUI的ScrollTab组件
2018/02/02 Javascript
angularJS实现动态添加,删除div方法
2018/02/27 Javascript
解决JavaScript中0.1+0.2不等于0.3问题
2018/10/23 Javascript
vue动态禁用控件绑定disable的例子
2019/10/28 Javascript
vue el-table实现行内编辑功能
2019/12/11 Javascript
[01:15]《辉夜杯》北京网鱼队巡礼
2015/10/26 DOTA
Python中return self的用法详解
2018/07/27 Python
pytorch SENet实现案例
2020/06/24 Python
QT5 Designer 打不开的问题及解决方法
2020/08/20 Python
canvas环形倒计时组件的示例代码
2018/06/14 HTML / CSS
Flesh Beauty官网:露华浓集团旗下彩妆品牌
2021/02/15 全球购物
C#如何调用Windows程序打开一个文档
2014/12/26 面试题
正规的求职信范文分享
2013/12/11 职场文书
莫言诺贝尔获奖演讲稿
2014/05/21 职场文书
幼儿园教师自我评价
2015/03/04 职场文书
2015年第31个教师节致辞
2015/07/31 职场文书
超级详细实用的pycharm常用快捷键
2021/05/12 Python
解读Vue组件注册方式
2021/05/15 Vue.js
MySQL通过binlog恢复数据
2021/05/27 MySQL
JS前端使用canvas实现物体的点选示例
2022/08/05 Javascript