四种浏览器对 clientHeight、offsetHeight、scrollHeight、clientWidth、offsetWidth 和 scrollWidth 的解释差异

四种浏览器对 clientHeight、offsetHeight、scrollHeight、clientWidth、offsetWidth 和 scrollWidth 的解释差异

448人阅读 评论(0) 收藏 举报

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

这里说说四种浏览器对 document.body 的 clientHeight、offsetHeight 和 scrollHeight 的解释。

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

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 的解释与上面相同,只是把高度换成宽度即可。


注:以上也是转的,对自己有点参考而已,有些值要跟据页面方式而定!我用的Ajax就完全没法用上面的方法定高!

javaScript窗口属性:
网页可见区域宽: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


在IE、FireFox、Opera下都可以使用
document.body.clientWidth
document.body.clientHeight
即可获得,很简单,很方便。
而在公司项目当中:
Opera仍然使用
document.body.clientWidth
document.body.clientHeight
可是IE和FireFox则使用
document.documentElement.clientWidth
document.documentElement.clientHeight
原来是W3C的标准在作怪啊
http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

 

 

 

 

 

 

 

 

 

 

 

 

 

1. clientHeight和offsetHeight的值由什么决定?

假如我们有以下的DIV,主要显示的文字为"This is the main body of DIV"。

 

 

 

如上图所示,clientHeight的值由DIV内容的实际高度和CSS中的padding值决定,而offsetHeight的值由DIV内容的实际高度,CSS中的padding值,scrollbar的高度和DIV的border值决定;至于CSS中的margin值,则不会影响clientHeight和offsetHeight的值。

 

2. CSS中的Height值对clientHeight和offsetHeight有什么影响?

首先,我们看一下CSS中Height定义的是什么的高度。如在本文最后部分“APPENDIX示例代码”(注:以下称为“示例代码”)中,innerDIVClass的Height值设定为50px,在IE下计算出来的值如下所示。也就是说,在IE里面,CSS中的Height值定义了DIV包括padding在内的高度(即offsetHeight的值);在Firefox里面,CSS中的Height值只定义的DIV实际内容的高度,padding并没有包括在这个值里面(70 = 50 + 10 * 2)。

 

in IE: 
innerDiv.clientHeight: 46
innerDiv.offsetHeight: 50
outerDiv.clientHeight: 0
outerDiv.offsetHeight: 264

in Firfox:
innerDiv.clientHeight: 70
innerDiv.offsetHeight: 74
outerDiv.clientHeight: 348
outerDiv.offsetHeight: 362

在上面的示例中,也许你会很奇怪,为什么在IE里面outerDiv.clientHeight的值为0。那是因为示例代码中,没有定义outerDIVClass的Height值,这时,在IE里面,则clientHeight的值是无法计算的。同样,在示例代码中,如果将innerDIVClass中的Height值去年,则innerDIV.clientHeight的值也为0。(注:在Firefox下不存在这种情况)。

如果CSS中Height值小于DIV要显示内容的高度的时候呢(当CSS中没有定义overflow的行为时)?在IE里面,整个clientHeight(或者offsetHeight)的值并没有影响,DIV会自动被撑大;而在Firefox里面,DIV是不会被撑开的。如在示例代码中,将innerDivClass的Height值设为0,则计算结果如下所示。IE里面的DIV被撑开,其clientHeight值等于内容的高度与padding*2的和;而Firefox里面,文字将溢出DIV的边界,其clientHeight值正好是padding值的两倍。

  In IE:
innerDiv.clientHeight: 38
innerDiv.offsetHeight: 42
outerDiv.clientHeight: 0
outerDiv.offsetHeight: 256

In Firefox:
innerDiv.clientHeight: 20
innerDiv.offsetHeight: 24
outerDiv.clientHeight: 298
outerDiv.offsetHeight: 312

APPENDIX 示例代码

<html>
<head>
<style type="text/css">......
.innerDivClass
{...}{...}{...}{
      color: red;
      margin: 37px;
      padding: 10px;
      border: 2px solid #000000;
      height: 50px;

 
}
.outerDivClass
{...}{...}{...}{
      padding: 100px;
      margin: 200px;
      border: 7px solid #000000;
}
</style>

<script>......
function checkClientHeight()
......{
      var innerDiv = document.getElementById("innerDiv");
      var outerDiv = document.getElementById("outerDiv");

      result.innerHTML = "innerDiv.clientHeight: " + innerDiv.clientHeight + "<br />";
      result.innerHTML += "innerDiv.offsetHeight: " + innerDiv.offsetHeight + "<br />";
      result.innerHTML += "outerDiv.clientHeight: " + outerDiv.clientHeight + "<br />";
      result.innerHTML += "outerDiv.offsetHeight: " + outerDiv.offsetHeight + "<br />";
}
</script>
</head>
<body>
<div id="outerDiv" class="outerDivClass">
<div class="innerDivClass" id="innerDiv">
Hello world.         
</div>
</div>
<p></p>
<div id="result">
</div>
<input type="button" οnclick="checkClientHeight()" text="Click Me" Value="Click Me" />
</body>
</html>

 


<think>嗯,用户问的是如何在Linux下给npm换源。首先,我需要回忆一下npm换源的常用方法。通常有两种方式:通过npm config命令直接修改注册表,或者使用nrm这样的源管理工具。 首先,用户可能是在国内,访问默认的npm源速度慢,所以需要换成国内的镜像源,比如淘宝源或者腾讯源。我需要确认正确的淘宝源地址,记得是https://registry.npmmirror.com,对吧?之前淘宝源换过域名,得确保是最新的。 接下来,用户可能不太熟悉命令行操作,所以步骤要详细。用npm config set registry命令来设置,然后通过npm config get registry检查是否生效。这个步骤比较简单,适合新手。 然后,考虑到用户可能想换回官方源,或者有其他需求,所以提供恢复默认源的命令也很重要。这里需要确认官方源的地址是https://registry.npmjs.org/,不能出错。 另外,有时候用户可能需要临时使用某个源,这时候可以用--registry参数,比如安装包的时候临时指定。这个场景虽然不常见,但可能对部分用户有用,应该提一下。 再考虑更进阶的工具nrm。安装nrm需要全局安装,可能会遇到权限问题,可能需要sudo或者调整npm的目录权限。使用nrm可以方便地测试不同源的响应速度,这对用户来说是个不错的建议。不过要提醒用户先安装nrm,然后列出源,切换,最后测试速度。 还有,用户可能不清楚这些操作背后的原理,比如修改的是全局配置还是项目级别的。需要说明这些配置是全局的,会影响所有项目,除非在项目内单独设置。如果有需要,用户可以在项目目录下使用.npmrc文件来覆盖全局设置,但这个问题可能超出当前问题的范围,暂时可以不提,除非用户进一步询问。 另外,注意安全性问题。提醒用户选择可信的镜像源,避免恶意源。这是很重要的,避免用户随便使用不可信的源导致安全问题。 用户可能遇到的问题包括:换源后仍然安装慢,这时候可能需要检查是否成功换源,或者是否有缓存。可以建议清除npm缓存,或者检查网络问题。不过用户没有提到安装问题,可能暂时不需要深入,但如果有常见问题,可以提前告知。 最后,确保所有的命令和步骤都正确,符合Linux环境下的操作,比如使用命令行终端,可能需要sudo权限来全局安装包,但npm通常不建议用sudo,所以如果用户遇到权限问题,可能需要指导他们修复npm的权限,或者使用nvm管理Node.js版本,避免权限问题。不过这可能超出当前问题的范围,所以暂时不提,除非用户进一步询问。 总结一下,步骤应该是先介绍直接修改注册表的方法,再介绍nrm工具,最后注意事项。确保每个步骤清晰,命令准确,同时覆盖到恢复默认源和临时使用的方法。此外,提醒用户选择可靠的镜像源,确保安全。</think>好的,以下是Linux系统下npm换源的详细步骤说明: --- ### 一、为什么要换源? 由于npm默认源(registry.npmjs.org)位于海外,国内访问速度较慢。更换为国内镜像源(如淘宝源、腾讯源)可显著提升依赖包的下载速度。 --- ### 二、三种换源方式 #### 1. 直接修改npm配置 ```bash # 设置为淘宝镜像源 npm config set registry https://registry.npmmirror.com # 验证是否生效 npm config get registry ``` #### 2. 使用临时源(仅单次生效) ```bash # 安装包时临时指定源 npm install <package-name> --registry=https://registry.npmmirror.com ``` #### 3. 使用工具nrm(推荐) ```bash # 全局安装nrm源管理工具 npm install -g nrm # 列出所有可用源 nrm ls # 切换到淘宝源 nrm use taobao # 测试源响应速度 nrm test ``` --- ### 三、恢复默认源 ```bash npm config set registry https://registry.npmjs.org/ ``` --- ### 四、常见镜像源列表 | 名称 | 镜像地址 | |----------|-----------------------------------| | 淘宝源 | https://registry.npmmirror.com | | 腾讯云 | https://mirrors.cloud.tencent.com/npm/ | | 华为云 | https://repo.huaweicloud.com/repository/npm/ | --- ### 五、注意事项 1. **权限问题**:若使用`npm install -g`报错,可在命令前加`sudo` 2. **缓存清理**:换源后若异常,可尝试 `npm cache clean --force` 3. **安全验证**:通过 `npm config list` 查看完整配置 4. **项目级配置**:在项目根目录添加 `.npmrc` 文件可覆盖全局配置 --- ### 六、验证操作 执行 `npm install lodash -g` 测试下载速度,观察是否提升。 若有其他问题(如企业私有源配置),可提供更多信息进一步分析。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值