html标签高度塌陷,CSS中如何解决高度塌陷问题

本文详细讲解了CSS中高度塌陷问题的成因,通过实例展示了如何通过设置固定高度、额外标签法、overflow属性和伪元素清除浮动来解决这一问题。重点介绍了BFC(块级格式化上下文)的概念及其在避免高度塌陷中的作用。
摘要由CSDN通过智能技术生成

CSS中如何解决高度塌陷问题

发布时间:2021-06-11 18:23:40

来源:亿速云

阅读:58

作者:Leah

这篇文章将为大家详细讲解有关CSS中如何解决高度塌陷问题,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

HTML:

first-child1
first-child2

second

third

CSS:.first{

width: 300px;

background-color: pink;

}

.first .first-child1,.first .first-child2{

float: left;

width: 100px;

height: 100px;

}

.first .first-child1{

background-color: purple;

margin-right: 10px;

}

.first .first-child2{

background-color: red;

}

.second{

width: 200px;

height: 150px;

background-color: blue;

}

.third{

width: 100px;

height: 150px;

background-color: green;

}

表现为:

e62dc138b48b8b4d3114a94f38b79a74.png

产生的原因

由上面的例子可以看出,first盒子没有设置高度,由子元素撑开,但是由于子盒子设置了浮动,脱离了标准流,所以导致first盒子没有高度,表现为second和third盒子向上移动了。

可以得出产生高度塌陷的原因:

在文档流中,父元素的高度默认是被子元素撑开的,也就是子元素多高,父元素就多高。但是当为子元素设置浮动以后,子元素会完全脱离文档流,此时将会导致子元素无法撑起父元素的高度,导致父元素的高度塌陷。由于父元素的高度塌陷了,则父元素下的所有元素都会向上移动,这样将会导致页面布局混乱。

高度塌陷的解决办法:

1、给父元素设置固定高度。但是使用这种方式后,父元素的高度就不能根据子元素自动撑高了,可以根据自己页面的特点,如果可以固定高度,可以使用这种方式,否则,不推荐这种方式。

2、额外标签法,这是w3c推荐的解决方案,但是不推荐,因为html的原则是写出语义化的标签,这种方式会额外增加无意义的标签。

first-child1
first-child2

3、父元素的overflow属性(开启元素的BFC):.clearfix{

overflow: hidden;

}

使用这种方式,属性值可以是非visible(hidden/auto/scroll)中任意,但是建议用hidden。

这种方式副作用较小,这种方式在ie6中不支持,可以外加zoom: 1;.clearfix::after{

content: "";/*伪元素内容为空*/

display: block;/*非默认的就行,也可以是table等等*/

height: 0;/*伪元素高度为0,不影响其他元素*/

clear: both;/*清除浮动*/

visibility: hidden;/*不可见*/

}

.clearfix{

zoom: 1;/*ie6元素没有BFC模式,但是这句代码会开启ie6中的hasLayout模式,只在ie中支持*/

}

4、单伪元素after清除浮动(开启元素的BFC):.clearfix::after{

content: "";/*伪元素内容为空*/

display: block;/*非默认的就行,也可以是table等等*/

height: 0;/*伪元素高度为0,不影响其他元素*/

clear: both;/*清除浮动*/

visibility: hidden;/*不可见*/

}

.clearfix{

zoom: 1;/*ie6元素没有BFC模式,但是这句代码会开启ie6中的hasLayout模式,只在ie中支持*/

}

这种方式现在使用比较广泛,很多大网站都是使用这种方式,副作用较小,只需要在配合处理ie6就可以了。

5、双伪元素清除浮动(开启元素的BFC):.clearfix::before,.clearfix::after{

content: "";

display: block;

clear: both;

}

.clearfix{

zoom: 1;/*ie6元素没有BFC模式,但是这句代码会开启ie6中的hasLayout模式,只在ie中支持*/

}

这种做法写法比较麻烦,也不推荐。

清除浮动对父元素的影响后的效果:

db133e20918e82612d5a31fb938045e3.png

BFC相关

根据W3C的标准,在页面中元素都一个隐含的属性叫做Block Formatting Context,简称BFC,该属性可以设置打开或者关闭,默认是关闭的。

当开启元素的BFC以后,元素将会具有如下的特性:

1.父元素的垂直外边距不会和子元素重叠

2.开启BFC的元素不会被浮动元素所覆盖

3.开启BFC的元素可以包含浮动的子元素

关于CSS中如何解决高度塌陷问题就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值