html高度100%不起作用,为什么你写的height:100%不起作用

为什么你写的height:100%不起作用?

这个知识不算冷门的,但是用的时候可能还是会有些懵逼,不能生效时搜一搜就能找到答案了,但是你真的懂了吗?为什么想要设置一个全屏元素的时候,高度不受%的控制?

1.百分比宽高的设定

6c42d091720ee4b48c82580d7f4355f7.png

2.width:100%;

我们写下这样一段代码,随意设置一个背景色便于观察元素。注意以下代码,记得加上,否则会有所不同。

width:100%;height:100%;

//宽100%,我们现在看到的高是属于font-size的,而不是100%;

f34810da7daa73d563c8176a7ab4bf83.png

width:100%;height:200px;

//效果如下

bdc7676d5d5abae55057a8bcf8c491d6.png

可以看到基本上宽的100%很容易就实现的,但是这里的height却不能设置成%比的(该元素会消失看不见),这是为什么呢?

3.浏览器是如何计算高度和宽度的

Web浏览器在计算有效宽度时会考虑浏览器窗口的打开宽度。如果你不给宽度设定任何缺省值,那浏览器会自动将页面内容平铺填满整个横向宽度。即我们不设置宽,会自动填满整个横向宽度,如下:

height:100%;

7cb90314c85d044685ec0b29382f9520.png

但是高度的计算方式完全不一样。事实上,浏览器根本就不计算内容的高度,除非内容超出了视窗范围(导致滚动条出现)。或者你给整个页面设置一个绝对高度。否则,浏览器就会简单的让内容往下堆砌,页面的高度根本就无需考虑。

因为页面并没有缺省的高度值,所以,当你让一个元素的高度设定为百分比高度时,无法根据获取父元素的高度,也就无法计算自己的高度。

即父元素的高度只是一个缺省值:height: auto;我们设置height:100%时,是要求浏览器根据这样一个缺省值来计算百分比高度时,只能得到undefined的结果。也就是一个null值,浏览器不会对这个值有任何的反应。

各个浏览器对于宽高的解析也不相同,大家可以自己搜索一下。

4.如何解决

现在你知道了吧,%是一个相对父元素计算得来的高度,要想使他有效,我们需要设置父元素的height;

要特别注意的一点是,在

之中的元素的父元素并不仅仅只是,还包括了。

所以我们要同时设置这两者的height,只设置其中一个是不行的:

html,body{

height: 100%;

margin: 0;

padding: 0;

}

c608c472e883e619c7f5e84d27f10617.png

5.关于line-height居中的一点误解?

Document

html,body{

height: 100%;

margin: 0;

padding: 0;

}

div {

color: white;

text-align: center;

font-size: 30px;

line-height: 100%;

background-color: blueviolet;

}

height:100%;

全部代码如上,可以看到设置了line-height为100%没有居中,这是为什么呢,因为这时候的%是相对于字体尺寸的?所以直接作用于没有绝对高度的元素是不行的。

cf250409de2879ade3c3fe44de1ff688.png

这时候要想居中,可以如下,做一个div嵌套,一个负责高度,一个负责居中,虽然感觉并不会这样用到,但是居中还是很灵验的~

Document

html,

body {

height: 100%;

margin: 0;

padding: 0;

}

.div1 {

background-color: blueviolet;

position: relative;

}

.div2 {

font-size: 30px;

color: white;

text-align: center;

width: 400px;

position: absolute;

left: 50%;

top: 50%;

transform: translateX(-50%) translateY(-50%);

}

height:100%;

2f43ed51afd9b3d0413a27ad1bcf906e.png

6.源码

搬运链接:

到此这篇关于为什么你写的height:100%不起作用 的文章就介绍到这了,更多相关height:100%不起作用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!

  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值