布局中造成盒子塌陷的原因是什么?怎么解决塌陷问题?

html-css021

布局中造成盒子塌陷的原因是什么?怎么解决塌陷问题?,第1张

为什么会出现盒子塌陷?

当父元素没设置足够大小的时候,而子元素设置了浮动的属性,子元素就会跳出父元素的边界(脱离文档流),尤其是当父元素的高度为auto时,而父元素中又没有其它非浮动的可见元素时,父盒子的高度就会直接塌陷为零, 我们称这是CSS高度塌陷。

下图下方两个子元素的盒子分别设置了左浮动和右浮动,顶端的长条盒子出现了塌陷

关于盒子塌陷的几种解决方法

(1)最简单,直接,粗暴的方法就是盒子大小写死,给每个盒子设 定固定的width和height ,直到合适为止,这样的好处是简单方便,兼容性好,适合只改动少量内容不涉及盒子排布的版面。缺点是非自适应,浏览器的窗口大小直接影响用户体验。

(2) 给外部的父盒子也添加浮动 ,让其也脱离标准文档流,这种方法方便,但是对页面的布局不是很友好,不易维护。

(3)给父盒子添加overflow属性。

        overflow:auto有可能出现滚动条,影响美观。

         overflow:hidden 可能会带来内容不可见的问题。

(4)父盒子里最下方引入清除浮动块。最简单的有:

        <br style=" clear:both "/>

有很多人是这么解决的,但是我们并不推荐,因为其引入了不必要的冗余元素 。

(5)用after伪元素清除浮动 

给外部盒子的after伪元素设置clear属性,再隐藏它 

这其实是对空盒子方案的改进,一种纯CSS的解决方案,不用引入冗余元素。

这也是bootstrap框架采用的清除浮动的方法。

这是一种纯CSS的解决浮动造成盒子塌陷方法,没有引入任何冗余元素,推荐使用此方法来解决CSS盒子塌陷。

备注:第五种方法虽好,但是低版本IE不兼容,具体选择哪种解决方法,可根据实际情况决定。

(6)给父盒子添加border

(7)给父盒子设置padding-top

推荐俩种依靠clear属于清除浮动的方法,推荐第二种,探究的记录在后面,赶时间的看个开头就好了。

1. 在受浮动坍塌的父级元素结束标签前,添加一个高宽为0的空div,然后设置 clear:both

2 .创建一个clearfix样式,并使用伪类元素 after 添加样式到父元素上

无论是块级元素还是行内元素设置了浮动之后都会生成一个块级框,并且可以编辑它的宽高,此时该浮动元素就脱离了文档流。举个例子,把网页看成一个三维的泳池,文档流在泳池底部,给文档流中一个元素设置了float之后,它就从这个网页的泳池底部浮动到了水上。此时同级的块级元素会无视float元素在网页上的位置进行布局。但是行内元素并不会被遮挡,而是像和它一起浮在水面上一样环绕这个浮动元素。

根据前面介绍,元素设置float后好像会从网页上浮一样,脱离文档流。这样的话,如果父级元素原本没设置高度,计划用子元素撑开父级元素。此时子元素因为float上浮,则父级元素的高度就会因为自身没设置而坍塌。

来个示例 ( 下文都是依据这个示例来讨论,故先给出HTML结构和CSS样式 ):

让我们再打开开发者工具具体看看

然后让我们把父元素也一同浮动看看

例如:

此时背景色为粉色的 ch2 就会被浮动的 背景色半透明的ch1 覆盖,但是ch2的字体还是环绕着ch1

如果让ch2 也浮动,则ch1 和 ch2 就相当于一同浮起到这个网页泳池的水面上。

另外,ch2 虽然不浮动起来时会被 同级ch1遮挡,但是ch2 它内部的行内元素却是环绕 ch1 的 ,同时 ch2 内部的块级元素还是会被浮动起来的ch1遮挡。

解决父元素高度坍塌的问题,其实可以给父元素指定个高度,但这样就没有父元素高度自适应的意义了;另外全部元素一起浮动也能解决父元素坍塌,子元素被遮挡的问题,但这本质上只是将所有元素一起浮动到顶端,并没有解决问题,反而还会影响另外的元素排列。下面介绍clear属性来清除浮动

那我们先来看看 clear 属性有什么用

我们稍稍改动一下上面的例子在 ch2 下加一个 p 标签然,然后改动一下 ch1 和 ch2 的样式让它们俩高度不一样。

若此时我们给p元素也加上浮动呢?

样例:

标准模型:box-sizing: content-box

IE 模型:box-sizing: border-box

什么是边距重叠呢?

边界重叠是指两个或多个盒子(可能相邻也可能嵌套)的相邻边界(其间没有任何非空内容、补白、边框)重合在一起而形成一个单一边界。

在这里父元素的高度不是 110px,而是 100px,在这里发生了高度坍塌。

原因是如果块元素的 margin-top 与它的第一个子元素的 margin-top 之间没有 border、padding、inline content、 clearance 来分隔,或者块元素的 margin-bottom 与它的最后一个子元素的 margin-bottom 之间没有 border、padding、inline content、height、min-height、 max-height 分隔,那么外边距会塌陷。子元素多余的外边距会被父元素的外边距截断。

可以看到 1 和 2,2 和 3 之间的间距不是 50px,发生了边距重叠是取了它们之间的最大值 30px。

假设有一个空元素,它有外边距,但是没有边框或填充。在这种情况下,上外边距与下外边距就碰到了一起,它们会发生合并

解决上述问题的其中一个办法就是创建 BFC。BFC 的全称为 Block Formatting Context ,即块级格式化上下文。

父子元素的边界重叠得解决方案: 在父元素上加上 overflow:hidden使其成为 BFC。

兄弟元素的边界重叠,在第二个子元素创建一个 BFC 上下文:

父元素#float 的高度为 0,解决方案为为父元素#float 创建 BFC,这样浮动子元素的高度也会参与到父元素的高度计算:

在这里设置右边的高度高于左边,可以看到右边超出的部分跑到左边去了,这是由于由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样导致的。

解决方案为给右侧元素创建一个 BFC,原理是 BFC 不会与 float 元素发生重叠。