flex平铺布局_cssflex布局详解
1,flex布局是个什么东西?
官⽅说法:Flex是Flexible Box的缩写,意为”弹性布局”,⽤来为盒状模型提供最⼤的灵活性。任何⼀个容器都可以指定为Flex布局。民间说法:flex 就是⼀种布局⽅式,类似于 block,inline-block等。
2,flex涉及的概念
Flex的基本作⽤就是让布局变的更简单,⽐如“垂直居中”等,当然不⽌这个,要说清楚flex有什么作⽤⾸先要了解⼀些概念。
采⽤Flex布局的元素,称为Flex容器(flex container),简称”容器”。它的所有⼦元素⾃动成为容器成员,称为Flex项⽬(flex item),简称”项⽬”。
容器默认存在两根轴:⽔平的主轴(main axis)和垂直的交叉轴(cross axis)。主轴的开始位置(与边框的交叉点)叫做main start,结束位置叫做main end;交叉轴的开始位置叫做cross start,结束位置叫做cross end。
项⽬默认沿主轴排列。单个项⽬占据的主轴空间叫做main size,占据的交叉轴空间叫做cross size。
主要记住 “容器”、“项⽬”、“主轴(横轴)”和“交叉轴(纵轴)”的意思和指向就⾏。
3,容器的属性
3.1 flex-direction
flex-direction 决定主轴的⽅向(即项⽬的排列⽅向)。它有4个可能的值 :
row(默认值):主轴为⽔平⽅向,起点在容器的左端。
row-rever:主轴为⽔平⽅向,起点在容器的右端。
column:主轴为垂直⽅向,起点在容器的上沿。
column-rever:主轴为垂直⽅向,起点在容器的下沿。
3.2 flex-wrap
默认情况下容器⾥变得额所有项⽬都排在⼀条线上,flex-wrap定义如果⼀⾏排不下 如何换⾏。它可能的值有三个:
nowrap(默认):不换⾏。
wrap:换⾏,第⼀⾏在上⽅。
wrap-rever:换⾏,第⼀⾏在下⽅。
3.3 flex-flow
flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。
3.4 justify-content
justify-content 定义了项⽬在主轴上的对齐⽅式。它可能的值有5个:
flex-start:向主轴的起始位置对齐,也就是从主轴的起始位置开始排列。如果使⽤flex-direction 属性改变的主轴的⽅向,那项⽬对应的排列⽅式也会变。
.container{
display:flex;
flex-direction:row;
justify-content:flex-start;
}
1
2
3
4
5
.container{
display:flex;
flex-direction:row-rever;
justify-content:flex-start;
}
1
2
3
4
5
flex-end:向主轴结束位置对齐,也就是从主轴结束的位置开始排列。和flex-start⼀样也和flex-direction有关。
.container{
display:flex;
flex-direction:row;
justify-content:flex-end;
}
1
2
3
4
5
center: 居中
.container{
display:flex;
flex-direction:row;
justify-content:center;
}
1
2
3
4
5
space-between:如果有两个以上的项⽬,则容器主轴的开始和结束位置各⼀个,其他的项⽬均匀排列,项⽬之间的间隔相等。排列顺序同样和flex-direction有关。如果只有两个项⽬则⼀边⼀个。如果只有⼀个项⽬则只在容器主轴的开始位置排列
space-around:每个项⽬两侧的间隔相等。所以,项⽬之间的间隔⽐项⽬与边框的间隔⼤⼀倍。排列顺序同样和flex-direction有关。如果只有⼀个项⽬则排列在中间。
3.5 align-items属性
align-items属性定义项⽬在交叉轴(纵轴)上如何对齐。它可能取5个值。具体的对齐⽅式与交叉轴的⽅向有关,下⾯假设交叉轴从上到下。flex-start:交叉轴的起点对齐。
flex-end:交叉轴的终点对齐。
center:交叉轴的中点对齐。
baline: 项⽬的第⼀⾏⽂字的基线对齐。
stretch(默认值):如果项⽬未设置⾼度或设为auto,将占满整个容器的⾼度。
3.6 align-content属性
align-content属性定义了多根轴线(多⾏)的对齐⽅式。如果项⽬只有⼀根轴线(⼀⾏),该属性不起作⽤。
如果flex-direction的值是column,则该属性定义了多列的对齐⽅式。如果项⽬只有⼀列,该属性不起左右。
stretch(默认值):多⾏占满整个交叉轴。
flex-start:与交叉轴的起点对齐。
flex-end:与交叉轴的终点对齐。
center:与交叉轴的中点对齐。
space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。
space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔⽐轴线与边框的间隔⼤⼀倍。
四、项⽬的属性
4.1 order属性
.item {
order:;
}
1
2
3
order属性定义项⽬的排列顺序。数值越⼩,排列越靠前,默认为0。
4.2 flex-grow属性
.item {
flex-grow:; /* default 0 */
}
1
2
3
4
flex-grow属性定义项⽬的放⼤⽐例,默认为0。
如果所有的item 的flex-grow的值都是⼀样的话那就是以item 的width为最⼩值平均分配主轴上的宽度。如果item没有设置width则所有的item平分主轴上的剩余宽度(多余空间)。
如果item的flex-grow的值不⼀样,那就是根据对应的⽐例来分配主轴上的剩余宽度(多余空间)。同样是以item设置的width为最⼩值。
如果item设置的max-width则放⼤的宽度不会超过该值。
4.3 flex-shrink属性
flex-shrink属性定义了项⽬的缩⼩⽐例,默认为1,即如果空间不⾜,该项⽬将缩⼩。
.item {
flex-shrink:; /* default 1 */
}
1
2
3
如果所有项⽬的flex-shrink属性都为1,当空间不⾜时,都将等⽐例缩⼩。如果⼀个项⽬的flex-shrink属性为0,其他项⽬都为1,则空间不⾜时,前者不缩⼩。
如果container容器设置的flex-wrap则不存在空间不⾜的情况,如果超过会⾃动换⾏。所以这时候设置flex-shrink也是不起作⽤的。
负值对该属性⽆效。
4.4 flex-basis属性
flex-basis属性定义了在分配多余空间之前,项⽬占据的主轴空间(main size)。浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项⽬的本来⼤⼩。
.item {
flex-basis:|auto; /* default auto */
}
1
2
3
它可以设为跟width或height属性⼀样的值(⽐如350px),则项⽬将占据固定空间。
4.5 flex属性
flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。
.item {
flex:none | [ ? || ]
}
1
2
3
该属性有两个快捷值:auto (1 1 auto) 和 none (0 0 auto)。
建议优先使⽤这个属性,⽽不是单独写三个分离的属性,因为浏览器会推算相关值。
如果flex-basis的总和加起来⼤于⽗级宽度,⼦级被压缩,最后的选择是flex-shrink来进⾏压缩计算
加权值 = son1 + son2 + …. + sonN;