如何在不使用表或JavaScript的情况下实现以下结构?白色边界代表div的边缘,与问题无关。

中间区域的大小会有所变化,但它会有精确的像素值,整个结构应该根据这些值缩放。为了简化它,我需要一种方法来设置“100% - n像素”的宽度为上-中和下-中div。

我很欣赏一个干净的跨浏览器解决方案,但如果不可能,CSS黑客也可以。

这里有个奖励。另一种结构我一直在挣扎,最终使用表格或JavaScript。它略有不同,但引入了新的问题。我主要是在基于jquery的窗口系统中使用它,但我想保持脚本的布局,只控制一个元素的大小(中间的一个)。


当前回答

我刚刚偶然发现的新方法:css calc():

.calculated-width {
    width: -webkit-calc(100% - 100px);
    width:    -moz-calc(100% - 100px);
    width:         calc(100% - 100px);
}​

css宽度100%减去100px

其他回答

也许我有点傻,但桌子不是最明显的解决办法吗?

<div class="parent">
    <div class="fixed">
    <div class="stretchToFit">
</div>

.parent{ display: table; width 100%; }
.fixed { display: table-cell; width: 150px; }
.stretchToFit{ display: table-cell; vertical-align: top}

另一种方法,我已经想出在chrome更简单,但人是一个hack!

.fixed{ 
   float: left
}
.stretchToFit{
   display: table-cell;
   width: 1%;
}

就像表格单元格一样,这应该水平填充行其余部分。然而,你会遇到一些奇怪的问题,它超过了它的父元素的100%,将宽度设置为百分比值可以解决这个问题。

通常的方法是Guffa所概述的嵌套元素。不得不添加额外的标记来获得所需的钩子,这有点令人遗憾,但在实践中,这里或那里的包装器div不会伤害任何人。

如果你必须这样做没有额外的元素(例如。当您无法控制页面标记时),您可以使用box-sizing,它具有相当不错但不完整或简单的浏览器支持。可能比依赖脚本更有趣。

可以使用嵌套元素和填充来获得工具栏上的左右边。div元素的默认宽度是auto,这意味着它使用可用宽度。然后,您可以添加填充元素,它仍然保持在可用的宽度。

下面是一个示例,您可以使用它将图像作为左右圆角,以及在它们之间重复的中心图像。

HTML:

<div class="Header">
   <div>
      <div>This is the dynamic center area</div>
   </div>
</div>

CSS:

.Header {
   background: url(left.gif) no-repeat;
   padding-left: 30px;
}
.Header div {
   background: url(right.gif) top right no-repeat;
   padding-right: 30px;
}
.Header div div {
   background: url(center.gif) repeat-x;
   padding: 0;
   height: 30px;
}

我刚刚偶然发现的新方法:css calc():

.calculated-width {
    width: -webkit-calc(100% - 100px);
    width:    -moz-calc(100% - 100px);
    width:         calc(100% - 100px);
}​

css宽度100%减去100px

在某些情况下,你可以利用边距设置来有效地指定“100%宽度减去N像素”。请看这个问题的公认答案。