虽然<div>这样的元素通常会增长以适应其内容,但使用float属性可能会给CSS新手带来一个惊人的问题:如果浮动元素具有非浮动的父元素,父元素将会折叠。

例如:

< div > < span style=" font - family:宋体;"> Div 1 < / Div > < span style=" font - family:宋体;"2 > Div < / Div > < / div >

本例中的父div不会展开以包含它的浮动子div——它看起来高度为:0。

你如何解决这个问题?

我想在这里创建一个详尽的解决方案列表。如果您知道跨浏览器兼容性问题,请指出来。

解决方案1

浮动父节点。

< span style=" font - family:宋体;"> < span style=" font - family:宋体;"> Div 1 < / Div > < span style=" font - family:宋体;"2 > Div < / Div > < / div >

优点:语义代码。 缺点:你可能不总是希望父元素浮动。即使你这样做了,你是否浮动了父母的父母等等?必须浮动每个祖先元素吗?

解决方案2

给父节点一个明确的高度。

< span style=" font - family:宋体;> < span style=" font - family:宋体;"> Div 1 < / Div > < span style=" font - family:宋体;"2 > Div < / Div > < / div >

优点:语义代码。 缺点:不灵活——如果内容改变或浏览器大小调整,布局就会中断。

解决方案3

在父元素中添加一个“spacer”元素,如下所示:

<div> <div style=“float: left;”>div 1</div> <div style=“float: left;”>div 2</div> <div class=“spacer” style=“clear: both;”></div> </div>

优点:编码简单明了。 缺点:没有语义性;分隔符div仅作为布局hack存在。

解决方案4

将parent设置为overflow: auto。

< span style=" font - family:宋体;"> < span style=" font - family:宋体;"> Div 1 < / Div > < span style=" font - family:宋体;"2 > Div < / Div > < / div >

优点:不需要额外的div。 缺点:看起来像一个黑客-这不是溢出属性的声明的目的。

评论?其他建议吗?


当前回答

我认为最好的方法是明确:既要对即将到来的元素。

原因如下:

1):after选择器在IE6/7中不支持,在FF3中有bug,但是 如果你只关心IE8+和FF3.5+清除:after可能对你来说是最好的…

2) overflow应该做一些其他的事情,所以这个hack不够可靠。

作者注意:在清算方面没有什么hack…清除意味着跳过浮动字段。CLEAR是自HTML3(谁知道呢,也许更久)http://www.w3.org/MarkUp/html3/deflists.html以来就与我们在一起了,也许他们应该选择一个有点不同的名字,比如page: new,但这只是一个细节…

其他回答

理想的解决方案是对列使用内联块,而不是浮动。我认为浏览器的支持是非常好的,如果你遵循(a)应用内联块的元素通常是内联的(如span);(b)为Firefox添加-moz-inline-box。

在FF2中检查你的页面,因为我在嵌套某些元素时遇到了很多问题(令人惊讶的是,这是IE比FF表现更好的一种情况)。

虽然代码不是完美的语义,但我认为在每个容器的底部都有一个我称之为“清除div”的东西会更直接。事实上,我在每个项目的重置块中都包含了以下样式规则:

.clear 
{
   clear: both;
}

如果你正在为IE6设计样式(上帝帮助你),你可能想给这个规则一个0px的line-height和height。

您可能会发现,将overflow更改为自动或隐藏的主要问题是,所有内容都可以通过鼠标中键滚动,用户可能会弄乱整个网站布局。

当一个被浮动的元素在一个容器盒子里时,这个问题就发生了,这个元素不会自动强迫容器的高度调整到被浮动的元素。当一个元素被浮动时,它的父元素将不再包含它,因为浮动已从流中移除。你可以使用两种方法来修复它:

{clear: both;} clearfix

一旦你理解了发生了什么,使用下面的方法来“清除”它。

.clearfix:after {
    content: ".";
    display: block;
    clear: both;
    visibility: hidden;
    line-height: 0;
    height: 0;
}

.clearfix {
    display: inline-block;
}

html[xmlns] .clearfix {
    display: block;
}

* html .clearfix {
    height: 1%;
}

示范:)

我最喜欢的方法是为父元素使用clearfix类

.clearfix:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}

.clearfix {
    display: inline-block;
}

* html .clearfix {
    height: 1%;
}

.clearfix {
    display: block;
}