flex属性
定义
flex布局包括最外层的容器和内部的元素,flex属性是内部元素属性。flex属性是flex-grow, flex-shrink, flex-basis三个属性的简写
flex-grow
设置元素占flex容器所剩空余空间的比例
flex-shrink
设置元素的收缩倍数,当元素的默认尺寸大于flex容器时,元素根据flex-shrink值缩小尺寸。
flex-basis
在不设置box-sizing属性的情况下,flex-basis设置flex元素的内容区(content box)的初始尺寸。
如果一个元素同时设置了flex-basis与width(如果flex-direction:column那么就是height)属性,flex-basis有更高的优先级
名词解释
主轴:flex-direction设置主轴方向,默认值为row,对应的主轴尺寸为width值(如果flex-direction是column那么主轴尺寸为height值)
父容器尺寸:外部容器在主轴上的尺寸(此例中为width值)
初始占用空间:内部元素设置好flex属性后,会有初始指定的占用空间
剩余可分配空间:父容器尺寸 - 初始总占用空间(所有内部元素的初始占用空间)
实例讲解
<div class="parent">
<div class="item-1"></div>
<div class="item-2"></div>
<div class="item-3"></div>
</div> <style type="text/css">
.parent {
display: flex;
width: 600px;
}
.parent > div {
height: 100px;
}
.item-1 {
width: 140px;
flex: 2 1 0%;
background: blue;
}
.item-2 {
width: 100px;
flex: 2 1 auto;
background: darkblue;
}
.item-3 {
flex: 1 1 200px;
background: lightblue;
}
</style>
运行结果
初始值
主轴上父容器总尺寸: 600px(此例中主轴为x轴,主轴尺寸为width)
- item-1的初始占用空间为 0% 即0px
- item-2的初始占用空间为 auto 即 100px(元素flex-basis设置为auto时,元素初始尺寸为width)
- item-3的初始占用空间为 200px
子元素的总初始占用空间: 0px + 100px + 200px = 300px
剩余空间分配
剩余空间 :600px - 300px = 300px
元素的放大系数由flex-grow决定,放大系数和为 item-1 (2) + item-2 (2) + item-3 (1) = 5
- item-1 剩余分配空间 2/5 * 300px = 120px
- item-2 剩余分配空间 2/5 * 300px = 120px
- item-3 剩余分配空间 1/5 * 300px = 60px
每个元素的最终width = 初始占用空间 + 剩余分配空间
- item-1 120px + 0px = 120px
- item-2 100px + 120px = 220px
- item-3 200px + 60px = 260px