前言
问题描述
最近在做页面排版时,利用flex布局,出现一个有意思的问题。
以上是一个最基础的布局之一,在父元素高度固定的情况下,需要在子元素1
固定的同时,让子元素2
将剩下的内容占据填充。
基础代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.parent_div{
height: 300px;
display: flex;
flex-direction: column;
background-color: #ccc;
}
.child_div_1{
height: 40px;
background-color: yellow;
}
.child_div_2{
flex: 1;
background-color: red;
}
</style>
</head>
<body>
<div class="parent_div">
<div class="child_div_1">
div1
</div>
<div class="child_div_2">
div2
</div>
</div>
</body>
</html>
很简单的一串h5标记语言。但有意思的来了。试着一直往child\_div\_2
中加入内容。
左侧为flex:1默认状态下的均摊div盒子高度效果,右侧为填充内容效果。
很好奇为什么会出现这种效果?原本已经被均摊的盒子高度,为什么还会超出?
flex特性
flex: 1
的作用:
flex-grow: 1
: 子元素将尝试占据父容器中所有可用的空间(在主轴方向上)。flex-shrink: 1
: 当父容器缩小时,子元素的尺寸会缩小。flex-basis: 0%
: 子元素的初始主轴尺寸被设定为 0,这使得flex-grow
和flex-shrink
能够工作。
子元素高度的默认行为:
- 在 Flexbox 布局中,子元素的高度通常由内容决定,即使设置了
flex: 1
,如果内容的高度超出了默认高度,子元素的高度会随内容变化。
解决方案
为了确保子元素的高度在使用 flex: 1
时不受内容高度变化的影响,可以通过设置 height: 0
<style>
……
.child_div_2{
flex: 1;
height: 0; //增加该处
background-color: red;
}
……
</style>
为什么设置 height: 0
:
- 通过设置
height: 0
,你告诉浏览器子元素的初始高度为 0。在这种情况下,flex-grow:
会使子元素根据父容器的高度均匀分配空而不会因为内容高度而改间,变。* 这就意味着,子元素会根据父容器的高度来确定自身高度,而不是根据内容高度。
同理宽度也如此
。
最终得到的效果
内容依旧还是会超出,但是高度已经限制,所以只需要对超出内容做出隐藏
或者截取
、省略号
等操作即可。