clientheight什么意思_汇编中offset是什么意思

clientheight什么意思_汇编中offset是什么意思许多文章已经介绍了clientHeight和offsetHeight的区别,就是clientHeight的值不包括scrollbar的高度,而offsetHeight的值包括了scrollbar的高度。然而,clientHeight和offsetHeight的值到底由什么组成的呢?如何计算这两个数的值?1.clientHeight和offsetHeight的值由什么决定?假如我们…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
许多文章已经介绍了clientHeight和offsetHeight的区别,就是clientHeight的值不包括scrollbar的高度,而offsetHeight的值包括了scrollbar的高度。然而,clientHeight和offsetHeight的值到底由什么组成的呢?如何计算这两个数的值?

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>

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195339.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • spss分析方法聚类分析_变量聚类分析

    spss分析方法聚类分析_变量聚类分析聚类分析是根据研究对象的特征,按照一定标准对研究对象进行分类的一种分析方法。下面我们主要从下面四个方面来解说:一、实际应用聚类分析的目标就是在相似的基础上收集数据来分类。聚类源于很多领域,包括数学,计算机科学,统计学,生物学和经济学。在不同的应用领域,很多聚类技术都得到了发展,这些技术方法被用作描述数据,衡量不同数据源间的相似性,以及把数据源分类到不同的簇中。商业上:聚类分析被用来发现不同的客户群,并且通过购买模式刻画不同的客户群的特征。聚类分析是细分市场的有效工具,同时也可用于研究消费者行为

    2022年10月18日
    3
  • matlab中doc怎么用_ipaddock栏设置

    matlab中doc怎么用_ipaddock栏设置dock栏是是苹果IOS系统或者MAC系统自带任务栏以及切换的快捷窗口,一般活动桌面为最下方固定的界面就是dock栏;MAC系统中的Dock栏,可以显示、切换下运行的程序,也可以单击上面的程序图标则启动那个程序。本文操作环境:iOS12.3.1系统,iPhone11。Dock栏就是苹果IOS系统或者MAC系统自带任务栏以及切换的快捷窗口,一般活动桌面为最下方固定的界面就是dock栏。MAC系统…

    2025年10月31日
    4
  • 如何更改Linux的ssh端口

    如何更改Linux的ssh端口

    2021年10月8日
    99
  • redis windons安装教程

    redis windons安装教程redis windons安装教程

    2022年4月24日
    40
  • mysql8.0配置允许远程连接_设置允许远程连接

    mysql8.0配置允许远程连接_设置允许远程连接一.设置Mysql远程登陆1.登进MySQL2.输入以下语句,进入mysql库:usemysql3.更新域属性,’%’表示允许任意IP地址访问:updateusersethost=’%’whereuser=’root’;4.执行以上语句之后再执行:FLUSHPRIVILEGES;5.再执行授权语句:GRANTALLPRIVI……

    2022年10月9日
    5
  • promptings是什么意思啊(think again)

    原文:http://windowsxp.mvps.org/890859.htm 当你通过Web方式的WindowsUpdates或者Windows自动更新安装完KB890859补丁后,系统依然不断提示此更新未安装,不断弹出安装对话框,可能的原因是一个或者多个主要的Windows文件未能成功地被此Hotfix更新或者覆盖导致,需要校验此更新是否成功,打开%WINDIR%/system32目录,

    2022年4月14日
    55

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号