float:分为左浮右浮 left/right
浮动的元素会脱离文档流 空间释放 宽高由内容撑开
子元素浮动会导致父元素高度塌陷
如何解决父元素的高度塌陷问题
-
给父元素加高度;
-
clear属性的空标签:在浮动元素后添加一个空标签 ,并且在CSS中设置.clear{clear:both;}
clear:both是css中清楚全部样式的意思
,即可清理浮动。- 原理:添加一个空标签,利用CSS提高的clear:both清除浮动,让父元素可以 自动获取到高度
- 优点:简单,代码少,兼容所有浏览器
- 缺点:增加页面的标签,造成结构的混乱
- 建议:不推荐使用,此方法已经过时
-
给浮动元素的容器添加一个clearfix的class,然后给这个class添加一个:after伪元素实现元素之后添加一个看不见的块元素(Block element)清理浮动。
- 原理:通过CSS伪元素在容器的内部元素之后添加一个看不见的空格“/20”或点“.” ,并且设置clear属性清除浮动。
- 优点:浏览器支持较好
- 缺点:clearfix这个class需要添加zoom: 1(触发haslayout),才能支持IE6和 IE7浏览器
- 建议:推荐使用,设置公共类,减少CSS代码
-
overflow:hidden;(触发BFC)
BFC
BFC (Box Formatting Context)(块级格式化上下文)内部布局不会影响到外部
触发BFC的条件:
1.HTML (即根元素)就可以触发
2.float属性不为none
3. position为absolute或fixed
4. display为inline-block table-cell table-capton flex 等
5.overflow不为visible
BFC布局规则
- 内部的box会在垂直方向,一个接一个地放置
- box垂直方向的距离由margin决定,属于同一个BFC的两个相邻box的margin会发生重叠
- BFC的区域不会与float box重叠
- BFC就是页面上的一个隔离的独立容器。内外不会互相影响。
- 计算BFC高度时,浮动元素也参与运算