页面位置 top、postop、scrolltop、offsetTop、scrollHeight、offsetHeight、clientHeight

本文深入探讨网页布局中top属性、posTop的区别、scrollTop滚动条应用、offsetHeight与scrollHeight的区别,以及如何通过实例理解这些概念。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.top

此属性仅仅在对象的定位(position)属性被设置时可用。否则,此属性设置会被忽略。

<span style="font-size:18px;"><strong><span style="color:#6633FF;"><div style="background-color:red; position:absolute; width:100px; height:100px;">
<p style="background-color:silver; position:absolute; top:-5px;">测试top</p>
</div> </span></strong></span>
上面是一个段落P包含在一个DIV内,可以看到P的top设置为-5px后,它的上边距超过了容器DIV的上边距,超过的这段距离就是设置的5px。
需要注意的是,DIV和P这一对包含元素,都需要设置position为absolute才能得到想要的结果,假如父元素不设置,则子元素的参照将是更上层定义过position的元素,直到整个文档;


2.posTop

posTop的数值其实和top是一样的,但区别在于,top固定了元素单位为px,而posTop只是一个数值,一般使用posTop来进行运算。

3.scrollTop

<span style="font-size:18px;"><strong><span style="color:#3366FF;"><div id="container" style="background-color:silver; width:100px; height:100px; overflow:auto;">
<p style="background-color:red;" mce_style="background-color:red;">
这里是文本
</p>
</div>
<script type="text/javascript"><!--
container.scrollTop = 12;
// --></script></span></strong></span>
这一段文本在这个100*100的DIV内无法完全显示,所以设置了overflow为auto,它会出现一个上下方向的滑动框,假如没有设置 id.scrollTop属性的话,默认情况下滑块位置在顶端。而设置了scrollTop值为12后,滑块的位置改变了,默认显示是卷过了12个象素的文本。如果设置overflow为hidden,则将会无法显示顶部12个象素的文本。
注意设置方式是id.scrollTop,而不是id.style.scrollTop。

4.offsetTop

如果元素 A 是 HTML 的 body 元素,其 display 属性计算值是 none,或者不具有 CSS 布局盒子,则返回 0,并停止本算法。
如果元素 A 的 offsetParent 是 null 或者是 HTML 的 body 元素,以 CSS 像素为单位返回元素 A 上边框距画布原点的垂直距离,并停止本算法。
以 CSS 像素为单位返回元素 A 上边框距其 offsetParent 上边框的距离

5. scrollHeight 与 offsetHeight与clientHeight

clientHeight
大家对 clientHeight 都没有什么异议,都认为是内容可视区域的高度,也就是说页面浏览器中可以看到内容的这个区域的高度,一般是最后一个工具条以下到状态栏以上的这个区域,与页面内容无关。
offsetHeight

IE、Opera 认为 offsetHeight = clientHeight + 滚动条 + 边框。
NS、FF 认为 offsetHeight 是网页内容实际高度,可以小于 clientHeight

scrollHeight
IE、Opera 认为 scrollHeight 是网页内容实际高度,可以小于 clientHeight。
NS、FF 认为 scrollHeight 是网页内容高度,不过最小值是 clientHeight

对某个HTML控件
offsetHeight是自身元素的高度,scrollHeight是 自身元素的高度+隐藏元素的高度

<font size="4"><font color="#FF0000" size="3"><span style="color:#000000;"><span style="font-size:18px;"><strong><span style="color:#6633FF;"><div id="container" style="background-color:silver; width:100px; height:100px; overflow:auto;">
<p style="background-color:red; height:250px; ">
别再做情人 做只猫 做只狗 不做情人 做只宠物至少可爱迷人 和你相交不浅无谓明日会被你憎</p>
</div>
<script type="text/javascript"><!--
alert(container.offsetHeight);
alert(container.scrollHeight);
// --></script> </span></strong></span></span></font></font>
将依次输出100,250。因为已经指定了元素的height为100px,所以offsetHeight始终为100px;内部元素为250px,而容器元素只有100px,那么还有150px的内容它无法显示出来,但它却是实际存在的,所以scrollHeight值为100+150=250。


<think>这段代码是VBScript(Visual Basic Script)代码,通常用于早期的网页脚本(如Internet Explorer)或Windows脚本宿主(WSH)环境。它定义了一个名为`Window_OnLoad`的子程序(Sub),当窗口加载时会自动执行。 ### 代码功能解释: 1. **`self.ResizeTo 320, 180`**:将当前窗口的宽度调整为320像素,高度调整为180像素。 2. **`screenWidth = window.screen.availWidth`**:获取屏幕的可用宽度(不包括任务栏等区域)。 3. **`screenHeight = window.screen.availHeight`**:获取屏幕的可用高度。 4. **`posLeft = (screenWidth - 320) / 2`**:计算窗口左上角的水平坐标,使窗口在水平方向上居中(窗口宽度为320,所以用屏幕可用宽度减去窗口宽度,然后除以2)。 5. **`posTop = (screenHeight - 180) / 2`**:计算窗口左上角的垂直坐标,使窗口在垂直方向上居中(窗口高度为180)。 6. **`self.MoveTo posLeft, posTop`**:将窗口移动到计算出的位置(居中)。 ### 注意: - 这段代码依赖于`self`对象,在网页环境中,`self`通常指向当前窗口对象。 - `window.screen.availWidth`和`window.screen.availHeight`是浏览器提供的屏幕可用尺寸(去掉任务栏等区域后的尺寸)。 - 这段代码通常放在`<script type="text/vbscript">`标签内,在支持VBScript的浏览器(如旧版IE)中运行。 ### 现代替代方案(JavaScript): 由于VBScript已逐渐被淘汰,现代网页开发通常使用JavaScript实现类似功能。以下是用JavaScript实现的等效代码: ```javascript window.onload = function() { // 调整窗口大小为320x180 window.resizeTo(320, 180); // 获取屏幕可用宽度和高度 const screenWidth = window.screen.availWidth; const screenHeight = window.screen.availHeight; // 计算居中位置 const posLeft = (screenWidth - 320) / 2; const posTop = (screenHeight - 180) / 2; // 移动窗口到计算的位置 window.moveTo(posLeft, posTop); }; ``` ### 注意事项: 1. 现代浏览器出于安全考虑,可能会限制`resizeTo`和`moveTo`方法的使用,尤其是在非用户触发的脚本中(如页面加载)。因此,这段代码可能无法在所有浏览器中正常运行。 2. 通常,浏览器只允许脚本调整由脚本打开的窗口(即`window.open`打开的窗口),而不是主窗口。 ### 相关问题: §§相关问题§§: 1. VBScript和JavaScript的主要区别是什么? 2. 在JavaScript中,如何获取浏览器窗口的尺寸(而不是屏幕的可用尺寸)? 3. 现代浏览器中,如何安全地调整窗口大小和位置? 4. 如何使一个窗口在打开时就居中显示(使用JavaScript)?</think>这段代码是使用 **VBScript** 编写的(通常用于经典 ASP 或旧版 Internet Explorer),主要功能是在窗口加载时自动调整窗口大小并居中显示。以下是逐行解释: ```vbscript Sub Window_OnLoad ' 定义窗口加载时触发的子程序 self.ResizeTo 320, 180 ' 将窗口大小调整为宽320像素、高180像素 screenWidth = window.screen.availWidth ' 获取屏幕可用宽度(排除任务栏等) screenHeight = window.screen.availHeight ' 获取屏幕可用高度 posLeft = (screenWidth - 320) / 2 ' 计算窗口居中的水平起始位置 posTop = (screenHeight - 180) / 2 ' 计算窗口居中的垂直起始位置 self.MoveTo posLeft, posTop ' 将窗口移动到计算出的居中位置 End Sub ``` ### 关键点说明: 1. **`Window_OnLoad`** 窗口加载事件的处理函数(类似 JavaScript 的 `window.onload`)。 2. **`self.ResizeTo`** 调整窗口尺寸(参数:宽度, 高度)。 3. **`window.screen.availWidth/Height`** 获取屏幕的**可用区域尺寸**(排除任务栏/工具栏)。 4. **居中计算逻辑** ```vbscript posLeft = (屏幕宽度 - 窗口宽度) / 2 ' 水平居中 posTop = (屏幕高度 - 窗口高度) / 2 ' 垂直居中 ``` 5. **`self.MoveTo`** 将窗口移动到指定坐标(参数:X坐标, Y坐标)。 ### 现代 JavaScript 等价实现 如果需要在现代浏览器中实现相同功能,可用以下 JavaScript 代码: ```javascript window.addEventListener('load', () => { // 设置窗口尺寸(仅对弹出窗口有效) window.resizeTo(320, 180); // 计算居中位置 const left = (screen.availWidth - 320) / 2; const top = (screen.availHeight - 180) / 2; // 移动窗口(仅对弹出窗口有效) window.moveTo(left, top); }); ``` ### 注意事项: - **浏览器限制**:现代浏览器出于安全考虑,通常禁止脚本控制主窗口大小/位置(`resizeTo/moveTo` 仅对 `window.open()` 创建的弹出窗口有效)。 - **VBScript 已淘汰**:该语言仅适用于旧版 IE,现代开发请使用 JavaScript。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值