我正在尝试填充Flexbox中的弹性项的垂直空间。

.容器{高度:200px;宽度:500px;显示:柔性;弯曲方向:行;}.flex-1型{宽度:100px;背景色:蓝色;}.flex-2型{位置:相对;挠曲:1;背景色:红色;}.flex-2-儿童{高度:100%;宽度:100%;背景色:绿色;}<div class=“container”><div class=“flex-1”></div><div class=“flex-2”><div class=“flex-2-child”></div></div></div>

这是JSFiddle

flex-2-child不能达到要求的高度,以下两种情况除外:

flex-2的高度为100%(这很奇怪,因为默认情况下flex-2具有100%的高度,而且在Chrome中存在bug)flex-2-child具有绝对位置,这也不方便

这在Chrome或Firefox中目前不起作用。


当前回答

我在这里回答了一个类似的问题。

我知道你已经说过立场:绝对;虽然不方便,但它可以工作。有关修复调整大小问题的更多信息,请参见下文。

也可以看到这个jsFiddle演示,尽管我只添加了WebKit前缀,在Chrome中如此开放。

你基本上有两个问题,我将分别处理。

使弹性项的子项填充高度100%

设置位置:相对;在孩子的父母身上。设置位置:绝对;在孩子身上。然后可以根据需要设置宽度/高度(在我的示例中为100%)。

修复Chrome中的调整大小滚动“怪癖”

放置溢出-y:自动;在可滚动分区上。可滚动div必须指定显式高度。我的示例已经具有100%的高度,但如果尚未应用,则可以指定高度:0;

有关滚动问题的更多信息,请参阅此答案。

其他回答

.容器{高度:200px;宽度:500px;显示:-moz框;显示:-webkit flexbox;显示:-ms flexbox;显示:-webkit flex;显示:-moz flex;显示:柔性;-webkit flex方向:行;-moz-flex方向:行;-ms flex方向:行;弯曲方向:行;}.flex-1型{柔性:100像素;背景色:蓝色;}.flex-2型{-moz-box flex:1;-webkit flex:1;-moz-flex:1;-ms flex:1;弹性:100%;背景色:红色;}.flex-2-儿童{弹性:100%;高度:100%;背景色:绿色;}<div class=“container”><div class=“flex-1”></div><div class=“flex-2”><div class=“flex-2-child”></div></div></div>

http://jsfiddle.net/2ZDuE/750/

如果我理解正确,您希望flex-2-child填充其父项的高度和宽度,以便红色区域被绿色完全覆盖?

如果是这样,您只需设置flex-2以使用Flexbox:

.flex-2 {
    display: flex;
}

然后告诉flex-2-child变得灵活:

.flex-2-child {
    flex: 1;
}

看见http://jsfiddle.net/2ZDuE/10/

原因是flex-2-child不是Flexbox项,但它的父项是。

另一种方法(其他选项不适合我的情况,因为我需要更通用的解决方案,我真的希望尽可能避免使用position:absolute,以及display:flex和align-items:stretch,因为其他syling在我的情况下不起作用):

具有显示的父对象:flex还可以让元素显示灵活,对齐self:stretch和margin-top:0+margin-bottom:0

最小可重复性示例:

.鹦鹉{显示:柔性;//宽度可以是任意的。宽度:150px;}.全高,仅含bg胶体{宽度:100%;显示:柔性;对齐自身:拉伸;//这可以仅为0,也可以仅设置顶部和底部值边距:0 2px;背景色:绿色;}<div><div class=“parrent”><div class=“full-height just with bg-color”></div>text高度</div></div>

我在这里回答了一个类似的问题。

我知道你已经说过立场:绝对;虽然不方便,但它可以工作。有关修复调整大小问题的更多信息,请参见下文。

也可以看到这个jsFiddle演示,尽管我只添加了WebKit前缀,在Chrome中如此开放。

你基本上有两个问题,我将分别处理。

使弹性项的子项填充高度100%

设置位置:相对;在孩子的父母身上。设置位置:绝对;在孩子身上。然后可以根据需要设置宽度/高度(在我的示例中为100%)。

修复Chrome中的调整大小滚动“怪癖”

放置溢出-y:自动;在可滚动分区上。可滚动div必须指定显式高度。我的示例已经具有100%的高度,但如果尚未应用,则可以指定高度:0;

有关滚动问题的更多信息,请参阅此答案。

这也可以通过对齐自身来解决:拉伸;在我们想要拉伸的元素上。

有时,在Flexbox设置中只拉伸一个项目是可取的。

.容器{高度:200px;宽度:500px;显示:柔性;弯曲方向:行;}.flex-1型{宽度:100px;背景色:蓝色;}.flex-2型{位置:相对;挠曲:1;对齐自身:拉伸;背景色:红色;}.flex-2-儿童{背景色:绿色;}<div class=“container”><div class=“flex-1”></div><div class=“flex-2”><div class=“flex-2-child”></div></div></div>