当父元素没设置足够大小的时候,而子元素设置了浮动的属性,子元素就会跳出父元素的边界(脱离文档流),尤其是当父元素的高度为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
首先我们先看出现外边距塌陷的三种情况: 1.当上下相邻的两个块级元素相遇,上面的元素有下边距margin-bottom,下面的元素有上边距margin-top,则它们之间的垂直距离取两个值中的较大者。 这时候两个盒子之间的垂直距离不是30px,而是20px。 解决方法: 尽量只给一个盒子添加margin值 2.对于两个嵌套关系的块元素,如果父元素没有上内边距及边框,父元素的上外边距会与子元素的上外边距发生合并,合并后的外边距为两者中的较大者。 这时候两个盒子会发生合并,上外边距为20px。 解决办法: ①给父元素定义上边框 ②给父元素定义上内边距 ③给父元素添加 overflow:hidden;④添加浮动 ⑤添加绝对定位 3.如果存在一个空的块级元素, border、padding、inline content、height、min-height 都不存在,那么上下边距中间将没有任何阻隔,上下外边距将会合并。 可以理解成中间div宽度为0且上下边距融合,只取margin的最大值。嵌套块元素外边距合并导致的塌陷(3种处理方法)
一、现象解释
指对于嵌套关系的块元素,若父子双方均有外边距则父元素会塌陷较大的外边距(通俗解释:就是父子均按照最大的外边距进行移动)
tips:谁大塌陷多少
eg:
<style>
.father{
width:500px
height:500px
background-color:rgb(15,213,240)
margin-top:100px
}
.son{
width:300px
height:300px
background-color:rgb(14,71,226)
margin-top:50px
}
</style>
<body>
<divclass="father">
<divclass="son">
</div>
</div>
</body>
二、解决方案
1.加一个透明的边框
即:加一个border: 1px solid transparent
<style>
.father{
width:500px
height:500px
background-color:rgb(15,213,240)
margin-top:100px
border:1pxsolidtransparent
}
.son{
width:300px
height:300px
background-color:rgb(14,71,226)
margin-top:50px
}
</style>
<body>
<divclass="father">
<divclass="son">
</div>
</div>
</body>
2.给父元素加一个内边距
即:padding:1px
<style>
.father{
width:500px
height:500px
background-color:rgb(15,213,240)
margin-top:100px
padding:1px
}
.son{
width:300px
height:300px
background-color:rgb(14,71,226)
margin-top:50px
}
</style>
<body>
<divclass="father">
<divclass="son">
</div>
</div>
</body>
3.给父元素加一个overflow:hidden
4.其他