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 相关文章推荐
window.event.keyCode兼容IE和Firefox实现js代码
May 30 Javascript
Jquery getJSON方法详细分析
Dec 26 Javascript
ajax+jQuery实现级联显示地址的方法
May 06 Javascript
Javascript连接Access数据库完整实例
Aug 03 Javascript
jQuery隐藏和显示效果实现
Apr 06 Javascript
Javascript Event(事件)的传播与冒泡
Jan 23 Javascript
jQuery实现文章图片弹出放大效果
Apr 06 jQuery
jQuery取得元素标签名称小结(附代码)
Aug 16 jQuery
微信小程序实现动态改变view标签宽度和高度的方法【附demo源码下载】
Dec 05 Javascript
vue+axios+element ui 实现全局loading加载示例
Sep 11 Javascript
vue单文件组件lint error自动fix与styleLint报错自动fix详解
Jan 08 Javascript
详解在微信小程序的JS脚本中使用Promise来优化函数处理
Mar 06 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中SQL注入攻击与XSS攻击
2012/06/10 PHP
php eval函数用法总结
2012/10/31 PHP
myEvent.js javascript跨浏览器事件框架
2011/10/24 Javascript
js查错流程归纳
2012/05/04 Javascript
js(JavaScript)实现TAB标签切换效果的简单实例
2014/02/26 Javascript
JavaScript简单表格编辑功能实现方法
2015/04/16 Javascript
JS实现网页右侧带动画效果的伸缩窗口代码
2015/10/29 Javascript
原生js页面滚动延迟加载图片
2015/12/20 Javascript
Javascript中的Prototype到底是什么
2016/02/16 Javascript
一系列Bootstrap导航条使用方法分享
2016/04/29 Javascript
js滚轮事件兼容性问题需要注意哪些
2016/11/15 Javascript
详解jQuery停止动画——stop()方法的使用
2016/12/14 Javascript
使用BootStrap实现表格隔行变色及hover变色并在需要时出现滚动条
2017/01/04 Javascript
详解Vue中过度动画效果应用
2017/05/25 Javascript
微信小程序实现页面浮动导航
2019/01/28 Javascript
微信小程序人脸识别功能代码实例
2019/05/07 Javascript
python中对list去重的多种方法
2014/09/18 Python
tensorflow 获取变量&amp;打印权值的实例讲解
2018/06/14 Python
python实现杨氏矩阵查找
2019/03/02 Python
用python打印1~20的整数实例讲解
2019/07/01 Python
使用Matplotlib 绘制精美的数学图形例子
2019/12/13 Python
简单了解python filter、map、reduce的区别
2020/01/14 Python
总结30个CSS3选择器
2017/04/13 HTML / CSS
CSS3 transforms应用于背景图像的解决方法
2019/04/16 HTML / CSS
会走动的图形html5时钟示例
2014/04/27 HTML / CSS
英国领先的汽车轮胎和快速健康中心:Kwik Fit
2017/10/29 全球购物
Hawes & Curtis澳大利亚官网:英国经典服饰品牌
2018/10/29 全球购物
HEMA法国:荷兰原创设计
2019/02/21 全球购物
Allen Edmonds官方网站:一家美国优质男士鞋类及配饰制造商
2019/03/12 全球购物
师范毕业生求职自荐信
2013/09/25 职场文书
毕业生自荐书
2013/12/18 职场文书
家长写给孩子的评语
2014/04/18 职场文书
爱国主义教育演讲稿
2014/08/26 职场文书
大学生助学金感谢信
2015/01/21 职场文书
GoLang中生成UUID唯一标识的实现
2021/05/08 Golang
Apache SkyWalking 监控 MySQL Server 实战解析
2022/09/23 Servers