offsetTop-clientTop-scrollTop-各属性介绍

来源:互联网 发布:詹姆斯退役数据预测 编辑:程序博客网 时间:2024/06/16 10:26

HTML 精确定位

scrollHeight: 获取对象的滚动高度
scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距离
scrollTop:设置或获取位于对象最顶端和窗口中可见内容的最顶端之间的距离
scrollWidth:获取对象的滚动宽度
offsetHeight:获取对象相对于版面或由父坐标 offsetParent 属性指定的父坐标的高度
offsetLeft:获取对象相对于版面或由 offsetParent 属性指定的父坐标的计算左侧位置
offsetTop:获取对象相对于版面或由 offsetTop 属性指定的父坐标的计算顶端位置
event.clientX 相对文档的水平座标
event.clientY 相对文档的垂直座标
event.offsetX 相对容器的水平坐标
event.offsetY 相对容器的垂直坐标
document.documentElement.scrollTop 垂直方向滚动的值
event.clientX+document.documentElement.scrollTop 相对文档的水平座标+垂直方向滚动的量


JS中建造迁移转变代码的常用属性

页可见区域宽: document.body.clientWidth;
网页可见区域高: document.body.clientHeight;
网页可见区域宽: document.body.offsetWidth (包含边线的宽);
网页可见区域高: document.body.offsetHeight (包含边线的宽);
网页正文全文宽: document.body.scrollWidth;
网页正文全文高: document.body.scrollHeight;
网页被卷去的高: document.body.scrollTop;
网页被卷去的左: document.body.scrollLeft;
网页正文项目组上:window.screenTop;
网页正文项目组左:window.screenLeft;
屏幕辨别率的高: window.screen.height;
屏幕辨别率的宽: window.screen.width;
屏幕可用工作区高度:window.screen.availHeight;

这里写图片描述


常见属性的简单介绍

offsetLeft

假设 obj 为某个 HTML 控件。

obj.offsetTopobj 间隔上方或上层控件的地位,整型,单位像素。
obj.offsetLeftobj 间隔左方或上层控件的地位,整型,单位像素。
obj.offsetWidthobj 控件自身的宽度,整型,单位像素。
obj.offsetHeightobj 控件自身的高度,整型,单位像素。

我们对前面提到的“上方或上层”与“左方或上层”控件作个申明。例如:

<div id="tool">    <input type="button" value="提交">    <input type="button" value="重置"></div>

“提交”按钮的 offsetTop 指“提交”按钮距“tool”层上边框的间隔,因为距其上边比来的是 “tool” 层的上边框。

“重置”按钮的 offsetTop 指“重置”按钮距“tool”层上边框的间隔,因为距其上边比来的是 “tool” 层的上边框。

“提交”按钮的 offsetLeft 指“提交”按钮距“tool”层左边框的间隔,因为距其左边比来的是“tool” 层的左边框。

“重置”按钮的 offsetLeft 指“重置”按钮距“提交”按钮右边框的间隔,因为距其左边比来的是“提交”按钮的右边框。以上属性在 FireFox 中也有效。

另 外:我们这里所说的是指 HTML 控件的属性值,并不是 document.bodydocument.body 的值在不同浏览器中有不同申明(实际上大多半景象是因为对 document.body 申明不合造成的,并不是因为对 offset 申明不合造成的),点击这里查看不合点。

题目:offsetTop 与 style.top 的差别

我们知道 offsetTop 可以获得 HTML 元素间隔上方或外层元素的地位,style.top 也是可以的,二者的差别是:

1.offsetTop 返回的是数字,而 style.top 返回的是字符串,除了数字外还带有单位:px

2.offsetTop 只读,而 style.top 可读写。

3.若是没有给 HTML 元素指定过 top 样式,则 style.top 返回的是空字符串。

offsetLeftstyle.leftoffsetWidthstyle.widthoffsetHeightstyle.height 也是同样事理。

clientHeight

clientHeight是内容可视区域的高度,也就是说页面浏览器中可以看到内容的这个区域的高度,一般是最后一个对象条以下到状况栏以上的这个区域,与页面内容无关。

简单地说 clientHeight 就是透过浏览器看内容的这个区域高度。

scrollLeft

scrollTop 是“卷”起来的高度值,示例:

<div style="width:100px;height:100px;background-color:#FF0000;overflow:hidden;" id="p"><div style="width:50px;height:300px;background-color:#0000FF;" id="t">若是为 p 设置了 scrollTop,这些内容可能不会完全显示。</div></div><script type="text/javascript">var p = document.getElementById("p");p.scrollTop = 10;</script>

因为为外层元素 p 设置了 scrollTop,所以内层元素会向上卷。scrollLeft 也是类似事理。我们已经知道 offsetHeight 是自身元素的宽度。而 scrollHeight 是内部元素的绝对宽度,包含内部元素的隐蔽的项目组。

上述中 p 的 scrollHeight 为 300,而 p 的 offsetHeight 为 100。scrollWidth 也是类似事理。

clientLeft

返回对象的 offsetLeft 属性值和到当前窗口左边的真实值之间的间隔,可以懂得为边框的长度。

一向以来对offsetLeftoffsetTopscrollLeftscrollTop这几个办法很含混,花了一天的时候好好的进修了一下.得出了以下的成果:

offsetTop

当前对象到其上级层顶部的间隔,不过不可对其进行赋值,设置对象到页面顶部的间隔请用 style.top 属性.

offsetLeft

当前对象到其上级层左边的间隔,不过不可对其进行赋值,设置对象到页面左部的间隔请用 style.left 属性

offsetWidth

当前对象的宽度,与 style.width 属性的差别在于:如对象的宽度设定值为百分比宽度,则无论页面变大还是变小,style.width都返回此百分比,而offsetWidth则返回在不合页面中对象的宽度值而不是百分比值

offsetHeight

style.height 属性的差别在于:如对象的宽度设定值为百分比高度,则无论页面变大还是变小,style.height 都返回此百分比,而offsetHeight则返回在不合页面中对象的高度值而不是百分比值

offsetParent

当前对象的上级层对象。

重视,若是对象是包含在一个DIV中时,此DIV不会被当做是此对象的上级层,(即对象的上级层会跳过DIV对象)上级层是 Table 时则不会有题目。

哄骗这个属性,可以获得当前对象在不合大小的页面中的绝对地位。获得绝对地位脚本代码:

function GetPositionobj){    var left = 0;    var top   = 0;    while(obj != document.body)    {        left = obj.offsetLeft;        top   = obj.offsetTop;        obj = obj.offsetParent;    }    alert("Left Is : " + left + "\r\n" + "Top   Is : " + top);}
scrollLeft

对象的最左边到对象在当前窗口显示的局限内的左边的间隔.

便是在呈现了横向迁移转变条的景象下,迁移转变条拉动的间隔.

scrollTop

对象的最顶部到对象在当前窗口显示的局限内的顶边的间隔.

便是在呈现了纵向迁移转变条的景象下,迁移转变条拉动的间隔.

阅读全文
0 0