首页 > 代码库 > CSS之float

CSS之float

在 HTML中的所有对象,默认分为两种:块元素(block element)、内联元素(inline element),虽然也存在着可变元素,但只是随上下文关系确定该元素是块元素或者内联元素。

其实CSS的float属性,作用就是改变块元素(block element)对象的默认显示方式。block对象设置了float属性之后,它将不再独自占据一行。可以浮动到左侧或右侧。

浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样。

请看下图,当把框 1 向右浮动时,它脱离文档流并且向右移动,直到它的右边缘碰到包含框的右边缘:

CSS之float详解 - 海上明月 - 心情驿站

再请看下图,当框 1 向左浮动时,它脱离文档流并且向左移动,直到它的左边缘碰到包含框的左边缘。因为它不再处于文档流中,所以它不占据空间,实际上覆盖住了框 2,使框 2 从视图中消失。

如果把所有三个框都向左移动,那么框 1 向左浮动直到碰到包含框,另外两个框向左浮动直到碰到前一个浮动框。

CSS之float详解 - 海上明月 - 心情驿站

如下图所示,如果包含框太窄,无法容纳水平排列的三个浮动元素,那么其它浮动块向下移动,直到有足够的空间。如果浮动元素的高度不同,那么当它们向下移动时可能被其它浮动元素“

CSS之float详解 - 海上明月 - 心情驿站  

 

行框和清理

浮动框旁边的行框被缩短,从而给浮动框留出空间,行框围绕浮动框。

因此,创建浮动框可以使文本围绕图像:CSS之float详解 - 海上明月 - 心情驿站

要想阻止行框围绕浮动框,需要对该框应用 clear 属性。clear 属性的值可以是 left、right、both 或 none,它表示框的哪些边不应该挨着浮动框。

为了实现这种效果,在被清理的元素的上外边距上添加足够的空间,使元素的顶边缘垂直下降到浮动框下面:

CSS之float详解 - 海上明月 - 心情驿站

 

让我们更详细地看看浮动和清理。假设希望让一个图片浮动到文本块的左边,并且希望这幅图片和文本包含在另一个具有背景颜色和边框的元素中。您可能编写下面的代码:

.news { background-color: gray; border: solid 1px black; }.news img { float: left; }.news p { float: right; }<div class="news"><img src="http://www.mamicode.com/news-pic.jpg" /><p>some text</p></div>

这种情况下,出现了一个问题。因为浮动元素脱离了文档流,所以包围图片和文本的 div 不占据空间。

 

如何让包围元素在视觉上包围浮动元素呢?需要在这个元素中的某个地方应用 clear:CSS之float详解 - 海上明月 - 心情驿站

不幸的是出现了一个新的问题,由于没有现有的元素可以应用清理,所以我们只能添加一个空元素并且清理它。

.news { border: solid 1px black; }.news img { float: right; }.news p { float: right; }

.clear { clear: both; }

<div class="news"><img src="http://www.mamicode.com/news-pic.jpg" /><p>some text</p>

<div class="clear"></div>

</div>

这样可以实现我们希望的效果,但是需要添加多余的代码。常常有元素可以应用 clear,但是有时候不得不为了进行布局而添加无意义的标记。

不过我们还有另一种办法,那就是对容器 div 进行浮动:

.news { border: solid 1px black;

float: left;

}.news img { float: right; }.news p { float: right; }<div class="news"><img src="http://www.mamicode.com/news-pic.jpg" /><p>some text</p></div>

这样会得到我们希望的效果。不幸的是,下一个元素会受到这个浮动元素的影响。为了解决这个问题,有些人选择对布局中的所有东西进行浮动,然后使用适当的有意义的元素(常常是站点的页脚)对这些浮动进行清理。这有助于减少或消除不必要的标记。

 

常用以下方法来给某个元素清除浮动

.clearfix:before, .clearfix:after { content: ‘\0020‘; display: block; height: 0; overflow: hidden; visibility: hidden; width: 100% }
  .clearfix:after { clear: both }
  .clearfix { zoom: 1 }

<div class="clearfix"></div>

 

 

CSS之float