快捷搜索:

js中top、clientTop、scrollTop、offsetTop的区别 文字详

网页可见区域宽: 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;

屏幕可用事情区宽度:window.screen.availWidth;

1、offsetLeft

假设 obj 为某个 HTML 控件。

obj.offsetTop 指 obj 间隔上方或上层控件的位置,整型,单位像素。

obj.offsetLeft 指 obj 间隔左方或上层控件的位置,整型,单位像素。

obj.offsetWidth 指 obj 控件自身的宽度,整型,单位像素。

obj.offsetHeight 指 obj 控件自身的高度,整型,单位像素。

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

例如:

“提交”按钮的 offsetTop 指“提交”按钮距“tool”层上边框的间隔,由于距其上边近来的是 “tool” 层的上边框。

“重置”按钮的 offsetTop 指“重置”按钮距“tool”层上边框的间隔,由于距其上边近来的是 “tool” 层的上边框。

“提交”按钮的 offsetLeft 指“提交”按钮距“tool”层左边框的间隔,由于距其左边近来的是 “tool” 层的左边框。

“重置”按钮的 offsetLeft 指“重置”按钮距“提交”按钮右边框的间隔,由于距其左边近来的是“提交”按钮的右边框。

以上属性在 FireFox 中也有效。

别的:我们这里所说的是指 HTML 控件的属性值,并不是 document.body,document.body 的值在不合浏览器中有不合解释(实际上大年夜多半情况是因为对 document.body 解释不合造成的,并不是因为对 offset 解释不合造成的),点击这里查看不合点。

标题:offsetTop 与 style.top 的差别

预备常识:offsetTop、offsetLeft、offsetWidth、offsetHeight

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

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

二、offsetTop 只读,而 style.top 可读写。

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

offsetLeft 与 style.left、offsetWidth 与 style.width、offsetHeight 与 style.height 也是同样事理。

标题:clientHeight、offsetHeight和scrollHeight

我们这里说说四种浏览器对 document.body 的 clientHeight、offsetHeight 和 scrollHeight 的解释,这里说的是 document.body,假如是 HTML 控件,则又有不合,点击这里查看。

这四种浏览器分手为IE(Internet Explorer)、NS(Netscape)、Opera、FF(FireFox)。

2、clientHeight

clientHeight

大年夜家对 clientHeight 都没有什么异议,都觉得是内容可视区域的高度,也便是说页面浏览器中可以看到内容的这个区域的高度,一样平常是着末一个对象条以下到状态栏以上的这个区域,与页面内容无关。

offsetHeight

IE、Opera 觉得 offsetHeight = clientHeight + 滚动条 + 边框。

NS、FF 觉得 offsetHeight 是网页内容实际高度,可以小于 clientHeight。

scrollHeight

IE、Opera 觉得 scrollHeight 是网页内容实际高度,可以小于 clientHeight。

NS、FF 觉得 scrollHeight 是网页内容高度,不过最小值是 clientHeight。

简单地说

clientHeight 便是透过浏览器看内容的这个区域高度。

NS、 FF 觉得 offsetHeight 和 scrollHeight 都是网页内容高度,只不过当网页内容高度小于即是 clientHeight 时,scrollHeight 的值是 clientHeight,而 offsetHeight 可以小于 clientHeight。

IE、Opera 觉得 offsetHeight 是可视区域 clientHeight 滚动条加边框。scrollHeight 则是网页内容实际高度。

同理

clientWidth、offsetWidth 和 scrollWidth 的解释与上面相同,只是把高度换成宽度即可。

然则

FF 在不合的 DOCTYPE 中对 clientHeight 的解释不合, xhtml 1 trasitional 中则不是如上解释的。其它浏览器则不存在此问题。

标题:scrollTop、scrollLeft、scrollWidth、scrollHeight

3、scrollLeft

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

假如为 p 设置了 scrollTop,这些内容可能不会完全显示。

因为为外层元素 p 设置了 scrollTop,以是内层元素会向上卷。

scrollLeft 也是类似事理。

我们已经知道 offsetHeight 是自身元素的宽度。

而 scrollHeight 是内部元素的绝对宽度,包孕内部元素的暗藏的部分。

上述中 p 的 scrollHeight 为 300,而 p 的 offsetHeight 为 100。

scrollWidth 也是类似事理。

IE 和 FireFox 周全支持,而 Netscape 和 Opera 不支持 scrollTop、scrollLeft(document.body 除外)。

颁发光阴:2007-10-15 20:20:16

标题:offsetTop、offsetLeft、offsetWidth、offsetHeight

4、clientLeft

返回工具的offsetLeft属性值和到当前窗口左边的真实值之间的间隔,可以理解为边框的长度

不停以来对offsetLeft,offsetTop,scrollLeft,scrollTop这几个措施很含混,花了一天的光阴好好的进修了一下.得出了以下的结果:

1.offsetTop:

当前工具到其上级层顶部的间隔.

不能对其进行赋值.设置工具到页面顶部的间隔请用style.top属性.

2.offsetLeft :

当前工具到其上级层左边的间隔.

不能对其进行赋值.设置工具到页面左部的间隔请用style.left属性.

3.offsetWidth :

当前工具的宽度.

与style.width属性的差别在于:如工具的宽度设定值为百分比宽度,则无论页面变大年夜照样变小,style.width都返回此百分比,而offsetWidth则返回在不合页面中工具的宽度值而不是百分比值

4.offsetHeight :

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

5.offsetParent:

当前工具的上级层工具.

留意.假如工具是包括在一个DIV中时,此DIV不会被当做是此工具的上级层,(即工具的上级层会跳过DIV工具)上级层是Table时则不会有问题.

使用这个属性,可以获得当前工具在不合大年夜小的页面中的绝对位置.

获得绝对位置脚本代码

复制代码 代码如下:

您可能还会对下面的文章感兴趣: