scrollTop,scrollHeight,clientTop,clientHeight,offsetTop,offsetHeight实际意义 及 计算方式 附实例说明
一、滚动距离、高度 scrollTop scrollLeft scrollHeight scrollWidth
二、相对位置、距离 offsetTop offsetLeft offsetHeight offsetWidth
三、可视距离、宽高 clientTop clientLeft clientHeight clientWidth
event.clientX event.clientY event.pageX event.pageY
event.offsetX event.offsetY event.layerX event.layerY
screenLeft screenTop screenX screenY
e.pageX e.pageY e.clientX e.clientY
一.滚动距离、高度
1.对象滚动条上面和左边折卷的距离(即浏览器滚动条滚动后顶部和左部被隐藏的页面内容像素)
javascript
document.documentElement.scrollTop//firefox
document.documentElement.scrollLeft//firefox
document.body.scrollTop//IE
document.body.scrollLeft//IE
jquery
$(window).scrollTop()
$(window).scrollLeft()
2.滚动对象元素的实际内容宽高,不含边框,包括被卷去看不见的部分。
javascript
document.body.scrollWidth //IE
document.body.scrollHeight //IE
document.documentElement.scrollWidth //firefox
document.documentElement.scrollHeight //firefox
jquery
无相关写法,但可获取同等高度
二.相对位置、距离
1.元素相对 最近有定位属性的父级元素 顶端和左边的偏移值 如果没有定位属性,默认为window
javascript
DOM元素对象.offsetTop //IE firefox
DOM元素对象.offsetLeft //IE firefox
jquery
jq对象.offset().top;
jq对象.offset().left;
2.元素本身的高度
javascript
obj.offsetWidth //obj元素的宽度 offsetWidth = width + padding + border
obj.offsetHeight //obj元素的高度 offsetHeight = width + padding + border
jquery
$(obj).outerHeight() //参数设为true 包括margin
$(obj).outerWidth() //参数设为true 包括margin
补充:$(obj).height() //不包括padding,border,margin
$(obj).innerHeight() //包括padding,不包括border,margin
三.可视距离、宽高
1.网页工作区域的高度和宽度(可见区域的宽度和高度)
javascript
document.documentElement.clientHeight; //IE firefox clientHeight = height + padding
document.documentElement.clientWidth; //IE firefox clientWidth = width + padding
jquery
$(window).innerHeight();
$(window).innerWidth();
2.元素周围边框的厚度
clientLeft //左边框的宽度
clientTop //右边框的宽度
四.坐标位置
1.相对文档
IE event.clientX event.clientY
firefix event.pageX event.pageY
2.相对容器
IE event.offsetX event.offsetY
firefox event.layerX event.layerY
3.获取浏览器在电脑屏幕中的位置
x=window.screenLeft || screenX;
y=window.screenTop || screenY;
4.获取鼠标在浏览器中的位置
$(obj).mousemove(function(e){
var x=e.pageX; // 这就是鼠标的x坐标 e.clientX也可以
var y=e.pageY; // 这就是鼠标的y坐标
})
5.获取鼠标在容器中的坐标
document.getElementById('box').onclick=function(e){
var x=e.offsetX || layerX; 这就是鼠标的x坐标
var y=e.offsetY || layerY; 这就是鼠标的y坐标
}
五.例子
1.css
.outer{
overflow:auto;
border:1px solid #;
height:300px;
width:300px;
padding:50px;
margin:0px;
}
.inner{
height:800px;
width:600px;
border:5px solid #;
}
2.dom
<div id="testDiv" class="outer">
<div class="inner"></div>
</div>
<div id="result" style="top:420px;left:20px;position:fixed;">
3.js
$(function(){
var element = document.getElementById("testDiv");
$(element).scroll(function(){
var str = "<div><span>滚动到最底端时:scrollTop+clientHeight=scrollHeight___</span>scrollTop:"+element.scrollTop
+"</div><div><span>滚动到最右端时:scrollLeft+clientWidth=scrollWidth___</span>scrollLeft:"+element.scrollLeft
+"</div><div><span>content(内部元素的实际高度)+padding-top___</span>scrollHeight:"+element.scrollHeight
+"</div><div><span>content(内部元素的实际宽度)+padding-left___</span>scrollWidth:"+element.scrollWidth
+"<br/><br/><div><span>相对最近有定位属性的父级元素 顶端的偏移___</span>offsetTop:"+element.offsetTop
+"</div><div><span>相对最近有定位属性的父级元素 左边的偏移___</span>offsetLeft:"+element.offsetLeft
+"</div><div><span>border+padding+content___</span>offsetHeight:"+element.offsetHeight
+"</div><div><span>border+padding+content___</span>offsetWidth:"+element.offsetWidth
+"<br/><br/><div><span>border-top___</span>clientTop:"+element.clientTop
+"</div><div><span>border-left___</span>clientLeft:"+element.clientLeft
+"</div><div><span>content+padding-滚动条的宽度___</span>clientHeight:"+element.clientHeight
+"</div><div><span>content+padding-滚动条的宽度___</span>clientWidth:"+element.clientWidth
+"</div>";
$("#result").html(str);
});
});
4.结果
结果说明:
滚动过程中,scrollTop和scrollLeft的值会变化。
//实际内容占的实际高度
scrollHeight = 810(inner 的 height+border)+50(outer 的 padding-top)。
offsetTop和offsetLeft为8px是浏览器的默认像素,此处指outer元素相对window的偏移。
//实际所占位置大小 包括border 不包括 margin
offsetHeight outer元素实际占位置的height outer 的 content+padding+border
clientTop outer的上边框
clientLeft outer的左边框
//实际可见区域
clientHeight outer的 content height+padding - 滚动条的宽度
clientWidth outer的 content width+padding - 滚动条的宽度


(本文供学习交流,欢迎大家共同讨论)
scrollTop,scrollHeight,clientTop,clientHeight,offsetTop,offsetHeight实际意义 及 计算方式 附实例说明的更多相关文章
- scrollHeight、clientHeight、offsetHeight、scrollTop等的定义以及图解
开发中经常遇到使用scrollHeight.scrollTop.clientHeight.offsetHeight等的情况,网上有众多关于这些属性的解释,但是并不全面和直观,现在将这些属性结合图例整理 ...
- 关于offsetTop offsetHeight clientHeight scrollHeight scrollTop的区别研究
我是以chrome浏览器做的研究. 先看一段代码: <script> window.addEventListener('DOMContentLoaded',function(){ var ...
- jquery 对象的 height、innerHeight、outerHeight 的区别以及DOM 元素的 clientHeight、offsetHeight、scrollHeight、offsetTop、scrollTop
前言:jquery 对象的 height.innerHeight.outerHeight,还有 DOM 元素的 clientHeight.offsetHeight.scrollHeight.offse ...
- offsetTop/offsetHeight scrollTop/scrollHeight 的区别
offsetTop/offsetHeight scrollTop/scrollHeight 这几个属性困扰了我N久,这次一定要搞定. 假设 obj 为某个 HTML 控件. obj.offset ...
- clientTop、offsetTop和scrollTop的区分
页可见区域宽: document.body.clientWidth; 网页可见区域高: document.body.clientHeight; 网页可见区域宽: document.body.offse ...
- 各种位置和高度计算:.position()、.offset()、.outerHeight()、.scrollTop、.scrollHeight、.clientHeight
1..position()和.offset() jquery的.position()获取相对于最近的position为relative或absolute的父元素的偏移,返回.position().le ...
- 四种浏览器对 clientHeight、offsetHeight、scrollHeight、clientWidth、offsetWidth 和 scrollWidth 的解释差异
网页可见区域宽:document.body.clientWidth 网页可见区域高:document.body.clientHeight 网页可见区域宽:document.body.offsetWid ...
- 详解clientHeight、offsetHeight、scrollHeight
关于clientHeight.offsetHeight.scrollHeight window.screen.availWidth 返回当前屏幕宽度(空白空间) window.screen.av ...
- height、clientHeight、offsetHeight、scrollHeight、height()、 innerHeight()、outerHeight()等的区别
1.height height是css属性,这个属性定义元素内容区的高度,在内容区外面可以增加内边距.边框和外边距. 当 box-sizing: content-box 时,高度应用到元素的内容框. ...
随机推荐
- Hibernate自动事务揪出的编码不规范
最近重构的项目(Java初学中),Service层一个获取通知记录报错: org.springframework.dao.InvalidDataAccessResourceUsageException ...
- 您厉害您赚得多:聪明投资者的聊天记录,雪球CEO的21条投资理念
3星|<您厉害您赚得多>:雪球创始人的投资理念.原则.技巧,及其在雪球上跟一些用户的互动的内容 作者是雪球创始人.CEO,全书基本是作者的一些投资理念+作者在雪球上跟用户的互动的内容,还有 ...
- linux最常用的快捷键
1.ctrl+alt+T 调出命令行界面 2.alt+f4 关闭当前窗口
- if判断,while循环,for循环
if判断 if判断其实就是让计算机模拟人的判断 if if 条件: 代码1 代码2 代码3 ... # 代码块(同一缩进级别的代码,例如代码1.代码2和代码3是相同缩进的代码,这三个代码组合在一起就是 ...
- .net 内嵌 GeckoWebBrowser (firefox) 核心浏览器
引用nuget包: 注意:Geckofx45 nuget包必须是最后引用,否则初始化会出错 简单示例: using Gecko; using System; using System.Collecti ...
- 如何在Centos里面,把.net core程序设为开机自启动
确定你的.net core程序可以在centos手动启动后,下一步,就是把这个程序做成一个服务,让它开机自自动了 1.创建脚本文件 到目录/etc/rc.d/init.d下面,创建一个myserver ...
- 如何在Ubuntu16.04 中安装Linux, Nginx, MySQL, PHP (LEMP 栈)
介绍 LEMP 栈是用来开发动态网页和web 应用程序的一系列软件集合,LEMP描述的是Linux操作系统,Nginx web 服务器,以及后端数据存储MySQL/MariaDB数据库和服务器端动态脚 ...
- 从CSV文件中读取jpg图片的URL地址并多线程批量下载
很多时候,我们的网站上传图片时并没有根据内容进行文件夹分类,甚至会直接存储到阿里云的OSS或是七牛云等云存储上.这样,当我们需要打包图片时,就需要从数据库找寻分类图片,通过CURL进行下载.我最近刚刚 ...
- 第七节:numpy之矩阵及特殊矩阵的创建
- 基于JavaScript封装的Ajax工具类
前段是件由于工作需要无奈编写了一个给予JavaScript封装的工具类,技术有限,误喷,感谢大家的支持. 1.以下是JavaScript 的 Ajax 工具类. function createXMLH ...