2

所以我在使用960网格系统,发现了一些他们不支持的东西。我考虑过切换到蓝图,但我必须在此过程中稍后再回到设计。无论如何,我已经简化了我的代码以显示我正在经历的事情:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 

Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">

<head>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type" />
<title>Test CSS</title>
<style type="text/css">
    .frame { width: 960px; margin-left: auto; margin-right: auto; }
    .column { display: inline; float: left; position: relative; margin: 10px 10px 10px 10px; width: 300px; background-color: silver; }
    #bkg { background-color: blue; }
</style>
</head>

<body>
    <div class="frame" id="bkg">
        <div class="column">Column A</div>
        <div class="column">Column B<div><br/><br/><br/><br/></div></div>
        <div class="column">Column C</div>
    </div>
</body>

</html>

我试图看到背景扩展以覆盖所有 3 列。我可以做些什么来扩展背景以使其涵盖所有 3 列吗?

4

4 回答 4

2

只需将此额外规则添加到您的选择器:

div.frame {
     overflow:hidden;
}

除非有元素出现在框架之外,否则您不应该依赖 clearfix,也不应该依赖 clear:both 的任何无关标记。

于 2009-09-30T03:24:20.297 回答
1

您需要将该clearfix类应用于#bkg。

<div class="frame clearfix" id="bkg">
于 2009-09-30T03:23:39.360 回答
1

您要做的是“清除浮动”。有很多选择,有些简单,有些相当复杂。

最简单的方法是在最后一列之后添加一个清除 div,如下所示:

<div class="frame" id="bkg">
  <div class="column">Column A</div>
  <div class="column">Column B<div><br/><br/><br/><br/></div></div>
  <div class="column">Column C</div>
  <div style="clear: both;"></div>
</div>

应该有效。

这里有一些其他的方式(一些,纯css):

于 2009-09-30T03:24:35.647 回答
1

您可以让框架浮动,如下所示:

.frame { width: 960px; margin-left: auto; margin-right: auto;float:left}

这就是它。或者,您可以通过“明确修复”在框架中添加一个额外的元素。预制的 960 网格通过“clear”类为您执行此操作:

(css  .clearfix { clear: both } )
<div class="frame"
   ...
<div class="clearfix" /></div>
于 2009-09-30T03:25:32.290 回答