一、浮动是什么
- 通过浮动可使一个元素向其父元素的左侧或右侧移动
float:left; 左侧移动,对齐 float:right; 右侧移动,对齐 注:设置浮动之后会脱离文档流,不再在文档中占用位置
二、清除浮动
1.为什么要清除浮动
清除浮动主要是为了解决,父元素因为子级元素浮动引起的内部高度为0的问题
注: 如果我们清除了浮动,父元素自动检测子盒子最高的高度,然后与其同高
2.怎么清除浮动
清除浮动常用的方法有四种:
- 额外标签法
- 父级添加overflow属性
- 使用after伪元素清除浮动
- 使用before和after双伪元素清除浮动
其中推荐使用after伪元素和使用before和after双伪元素清除浮动,代码较为简单,使用也方便。
额外标签法:
在最后一个浮动标签后,新加一个标签,给其设置clear:both;
优点:通俗易懂,方便
缺点:添加无意义标签,语义化差
注:clear:both:本质就是闭合浮动, 就是让父盒子闭合出口和入口,不让子盒子出来
父级添加overflow属性:
父元素添加overflow:hidden,通过触发BFC方式,实现清除浮动
优点:代码简洁
缺点:内容增多的时候容易造成不会自动换行导致内容被隐藏掉,无法显示要溢出的元素
使用after伪元素清除浮动:
.clearfix:after{/*伪元素是行内元素 正常浏览器清除浮动方法*/
content: "";
display: block;
height: 0;
clear:both;
visibility: hidden;
}
.clearfix{
*zoom: 1;/*ie6清除浮动的方式 *号只有IE6-IE7执行,其他浏览器不执行*/
}
在父元素中使用after伪元素清除浮动
优点:符合闭合浮动思想,结构语义化正确
缺点:ie6-7不支持伪元素:after,使用zoom:1触发hasLayout.
使用before和after双伪元素清除浮动 :
.clearfix:after,.clearfix:before{
content: "";
display: table;
}
.clearfix:after{
clear: both;
}
.clearfix{
*zoom: 1;
}
在父元素中使用使用before和after双伪元素清除浮动
优点:代码更简洁
缺点:用zoom:1触发hasLayout.