js得到屏幕宽高、页面宽高 (window.screen.availHeight)等

本文介绍了如何使用JavaScript获取屏幕的实际分辨率与可用区域大小,以及如何获取当前网页的高度和宽度。具体包括window.screen.width、window.screen.height、window.screen.availWidth、window.screen.availHeight、window.document.body.offsetHeight和window.document.body.offsetWidth等属性。

终于能分清楚这些区别了

window.screen.availWidth 返回当前屏幕宽度(空白空间) 

window.screen.availHeight 返回当前屏幕高度(空白空间) 
window.screen.width 返回当前屏幕宽度(分辨率值) 
window.screen.height 返回当前屏幕高度(分辨率值) 
window.document.body.offsetHeight; 返回当前网页高度 
window.document.body.offsetWidth; 返回当前网页宽度
<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、付费专栏及课程。

余额充值