我找到了一种方法,使一个div容器占据至少一个页面的全部高度,通过设置最小高度:100%;。然而,当我添加一个嵌套的div并设置高度:100%;,它不会延伸到容器的高度。有办法解决吗?

Html, body { 高度:100%; 保证金:0; } #控制{ 最小高度:100%; 背景:粉色; } # containment-shadow-left { 高度:100%; 背景:水; } < div id = "容器" > < div id = " containment-shadow-left " > 你好世界! < / div > < / div >


当前回答

虽然显示:伸缩;这里已经建议,考虑使用显示:网格;现在它得到了广泛支持。默认情况下,网格的唯一子节点将完全填充其父节点。

Html, body { 高度:100%; 保证金:0; 填充:0;/*不要忘记Safari */ } #控制{ 显示:网格; 最小高度:100%; 背景:粉色; } # containment-shadow-left { 背景:水; }

其他回答

这对我来说通常是有效的:

.parent { 最小高度:100 px; 背景颜色:绿色; 显示:flex; } .child { 高度:继承; 宽度:100%; 背景颜色:红色; } <!DOCTYPE html > < html > 身体< > < div class = "父" > < div class = "孩子" > < / div > < / div > 身体< / > < / html >

在尝试了我们的之后!chrome理解,当我设置显示值为inline block时,我希望子元素的高度为100%。顺便说一句,设置浮动会导致它。

display:inline-block

更新

这行不通。解决方案是获得parentnode offsetheight,并使用它在页面的和javascript。

<script>
    SomedivElement = document.getElementById('mydiv');
    SomedivElement.style.height = String(nvleft.parentNode.offsetHeight) + 'px';    
</script>

虽然显示:伸缩;这里已经建议,考虑使用显示:网格;现在它得到了广泛支持。默认情况下,网格的唯一子节点将完全填充其父节点。

Html, body { 高度:100%; 保证金:0; 填充:0;/*不要忘记Safari */ } #控制{ 显示:网格; 最小高度:100%; 背景:粉色; } # containment-shadow-left { 背景:水; }

添加这个到父组件为我修复了它:

display: flex;
flex-direction: column;

Kushagra Gour的解决方案确实有效(至少在Chrome和IE中),并且无需使用display: table就解决了原来的问题;并显示:table-cell;。参见plunker: http://plnkr.co/edit/ULEgY1FDCsk8yiRTfOWU

设置min-height: 100%;身高:1 px;在外部div上,使其实际高度至少为100%。它还允许内部div正确继承高度。