我有一个网站,其布局已在图表中显示。正文由main container
组成,其中包含header
,parent div
和footer
。 parent div
进一步包含多个child div
,如图所示。
问题是所有child div
的高度都是有限的。但parent div
只包含子div。所有子div都可见,但父div的高度显示为零。我也没有通过给出一些预先指定的值来修正父div的高度,因为如果将来孩子的数量增加可能会导致错误。
由于父div的大小为零而导致的问题是我的页脚div正在上升并与父div的内容发生冲突。这可以通过给出合适的margin-top来解决,但这不是我正在寻找的解决方案。
任何人都可以通过某种方式建议我,以便父div的高度根据子div的高度自动更改。
如果我不清楚我的疑问,请发表评论!
答案 0 :(得分:81)
好像你有clearfix class的案例。
所以我猜你是漂浮了孩子div,这就是父div的高度为0的原因。 当您使用浮动时,父级不适应子级的高度。
您可以将'clearfix'类应用于浮动元素的父级(当然,您需要在样式表中使用它),它将添加一个不可思议的“。”在末尾。然后你的父母将拥有正确的身高。
注意,它是跨平台的,兼容IE6 +,Chrome,Safari,Firefox,你可以命名它!
.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%;
}
答案 1 :(得分:48)
尝试将以下内容添加到样式表中:
#parentdiv:after {
content: " ";
display: block;
clear: both;
}
正如代达罗斯在评论中所说,你可能会漂浮孩子们。如果是这样,上面的行修复了它。
浮动事物时的问题是它们的父元素“忽略”它们。
上面的行创建并在#parentdiv中插入一个(伪)元素,该元素被向下推过所有浮动的div。然后,父div虽然忽略了浮动的子节点,但它不会忽略这个伪元素 - 按照它应该的方式运行,它会扩展为包含伪元素。现在,由于伪元素低于所有浮动的子元素,所以父div发生,或者更好,似乎也“包含”浮动的子元素 - 这正是你想要的。