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 相关文章推荐
用Javscript实现表单复选框的全选功能
May 25 Javascript
javascript从右边截取指定字符串的三种实现方法
Nov 29 Javascript
html文档中的location对象属性理解及常见的用法
Aug 13 Javascript
jquery mobile页面跳转后样式丢失js失效的解决方法
Sep 06 Javascript
javascript实现checkbox全选的代码
Apr 30 Javascript
JS+CSS实现鼠标经过弹出一个DIV框完整实例(带缓冲动画渐变效果)
Mar 25 Javascript
原生js简单实现放大镜特效
May 16 Javascript
JS的函数调用栈stack size的计算方法
Jun 24 Javascript
详解npm 配置项registry修改为淘宝镜像
Sep 07 Javascript
vue2.0 可折叠列表 v-for循环展示的实例
Sep 07 Javascript
NUXT SSR初级入门笔记(小结)
Dec 16 Javascript
three.js 实现露珠滴落动画效果的示例代码
Mar 01 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&amp;java(二)
2006/10/09 PHP
杏林同学录(七)
2006/10/09 PHP
php调用新浪短链接API的方法
2014/11/08 PHP
ThinkPHP模版引擎之变量输出详解
2014/12/05 PHP
PHP制作用户注册系统
2015/10/23 PHP
php上传excel表格并获取数据
2017/04/27 PHP
页面中body onload 和 window.onload 冲突的问题的解决
2009/07/01 Javascript
JS关键字变色实现思路及代码
2013/02/21 Javascript
Lua表达式和控制结构学习笔记
2014/12/15 Javascript
javascript实现数组内值索引随机化及创建随机数组的方法
2015/08/10 Javascript
jQuery检测滚动条是否到达底部
2015/12/15 Javascript
JavaScript的Backbone.js框架环境搭建及Hellow world示例
2016/05/07 Javascript
Node.js中看JavaScript的引用
2017/04/22 Javascript
Node.js npm命令运行node.js脚本的方法
2018/10/10 Javascript
微信小程序实现日历效果
2018/12/28 Javascript
JS温故而知新之变量提升和时间死区
2019/01/27 Javascript
详解JavaScript中的坐标和距离
2019/05/27 Javascript
新手快速入门JavaScript装饰者模式与AOP
2019/06/24 Javascript
vue.js中ref和$refs的使用及示例讲解
2019/08/14 Javascript
解决layui的table插件无法多层级获取json数据的问题
2019/09/19 Javascript
详解JavaScript作用域、作用域链和闭包的用法
2020/09/03 Javascript
[52:03]Secret vs VG 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
python时间整形转标准格式的示例分享
2014/02/14 Python
python3爬取数据至mysql的方法
2018/06/26 Python
python版本五子棋的实现代码
2018/12/11 Python
Python标准库使用OrderedDict类的实例讲解
2019/02/14 Python
详解python 利用echarts画地图(热力图)(世界地图,省市地图,区县地图)
2019/08/06 Python
django中间键重定向实例方法
2019/11/10 Python
Pytorch 搭建分类回归神经网络并用GPU进行加速的例子
2020/01/09 Python
pytorch cuda上tensor的定义 以及减少cpu的操作详解
2020/06/23 Python
python 实现端口扫描工具
2020/12/18 Python
五一口号
2014/06/19 职场文书
2014教师党员自我评议总结
2014/09/19 职场文书
新员工考核评语
2014/12/31 职场文书
服装店员工管理制度
2015/08/07 职场文书
Python Pandas 删除列操作
2022/03/16 Python