我有一个容器,里面有两个div:
容器的高度固定为500px。 我不知道头部的大小,但我想用身体填充所有的容器高度。 我试图将此高度值设置为body:
如何用合身体填充容器?
这是示例的小提琴:
#body{ height 100%; }
答案 0 :(得分:2)
这是flexbox的用途:
.container {
display: flex;
flex-direction: column;
height: 500px;
padding: 10px;
background-color: yellow;
}
.header {
background-color: lightblue;
}
.body {
flex: 1;
background-color: tomato;
}

<div class="container">
<div class="header">Header<br>unknown<br>height</div>
<div class="body"></div>
</div>
&#13;
答案 1 :(得分:1)
可以使用display: table/table-row
:
html {
box-sizing: border-box;
}
*, *:before, *:after {
box-sizing: inherit;
}
body{
margin: 0;
}
.container{
display:table;
width: 100%;
height: 500px;
background-color: red;
padding: 0 10px;
}
.head, .body{
display: table-row;
}
.head{
background-color: blue;
}
.body{
background-color: yellow;
height: 100%;
}
<div class="container">
<div class="head">some head</div>
<div class="body">foobar</<div>
</div>
另外,我使用box-sizing: border-box。