给一个父元素(包含三个兄弟子元素-头部,主题,底部)设置弹性盒,并设置高度百分百,然后分别给头部子元素,底部子元素设置高度,主题子元素设置flex:1。运行之后我们会发现并不是高度百分百状态(没有铺满整个屏幕),父元素高度设置无效。
代码图示如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.box{
display: flex;
flex-direction: column;
height: 100%;
}
.header{
height: 100px;
background-color: pink;
}
.main{
flex: 1;
background-color: rgb(0, 255, 76);
}
.footer{
height: 100px;
background-color: yellow;
}
</style>
</head>
<body>
<div class="box">
<div class="header">头部</div>
<div class="main">主体</div>
<div class="footer">底部</div>
</div>
</body>
</html>
运行结果:
那么怎么解决高度设置百分百无效问题呢?给html和body都设置上高度100%的样式就可以啦~
body,html{
height: 100%;
}