如何在不使用表或JavaScript的情况下实现以下结构?白色边界代表div的边缘,与问题无关。
中间区域的大小会有所变化,但它会有精确的像素值,整个结构应该根据这些值缩放。为了简化它,我需要一种方法来设置“100% - n像素”的宽度为上-中和下-中div。
我很欣赏一个干净的跨浏览器解决方案,但如果不可能,CSS黑客也可以。
这里有个奖励。另一种结构我一直在挣扎,最终使用表格或JavaScript。它略有不同,但引入了新的问题。我主要是在基于jquery的窗口系统中使用它,但我想保持脚本的布局,只控制一个元素的大小(中间的一个)。
我们可以很容易地使用flex-box来实现这一点。
如果我们有三个元素,Header, MiddleContainer和Footer。我们想给页眉和页脚一些固定的高度。然后我们可以这样写:
对于React/RN(默认是'display' as flex和'flexDirection' as column),在web css中,我们必须指定包含这些的体容器或容器为display: 'flex', flex-direction: 'column',如下所示:
container-containing-these-elements: {
display: flex,
flex-direction: column
}
header: {
height: 40,
},
middle-container: {
flex: 1, // this will take the rest of the space available.
},
footer: {
height: 100,
}
也许我有点傻,但桌子不是最明显的解决办法吗?
<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%,将宽度设置为百分比值可以解决这个问题。