flex弹性盒模型
-
什么是flex布局
Flex 是 Flexible Box 的缩写,意为"弹性布局",比较适合小规模的布局,移动端基本都是使用flex布局 -
flex有什么用
Flex 能为盒状模型提供最大的灵活性。提供一个更有效地布局、对齐方式等。 -
flex布局本质
flex布局实质上是一套属性的组合,有的属性是设置在父元素上,有的属性设置在子元素上。(大概12个属性,六个在父元素上,六个在子元素上),然后通过这12个属性来实现整体布局。
此时的父元素我们称之为flex容器,子元素我们称之为flex子项。 -
容器属性
一.flex-direction属性决定主轴的方向(即项目的排列方向)。
.box {
flex-direction: row | row-reverse | column | column-reverse;
}
二.flex-wrap属性定义,如果一条轴线排不下,如何换行。
.box{
flex-wrap: nowrap | wrap | wrap-reverse;
}
三.flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。
.box {
flex-flow: <flex-direction> || <flex-wrap>;
}
四.justify-content属性定义了项目在主轴上的对齐方式。
.box {
justify-content: flex-start | flex-end | center | space-between | space-around;
}
五.align-items属性定义项目在交叉轴上如何对齐。
.box {
align-items: flex-start | flex-end | center | baseline | stretch;
}
六.align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。
.box {
align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}
-
项目属性
一、order属性定义项目的排列顺序。数值越小,排列越靠前,默认为0。
.item {
order: <integer>;
}
二、flex-grow属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。
.item {
flex-grow: <number>; /* default 0 */
}
三、flex-shrink属性定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。
.item {
flex-shrink: <number>; /* default 1 */
}
四、flex-basis属性定义了在分配多余空间之前,项目占据的主轴空间(main size)。浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项目的本来大小。
.item {
flex-basis: <length> | auto; /* default auto */
}
五、flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。
.item {
flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
}
六、align-self属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。
.item {
align-self: auto | flex-start | flex-end | center | baseline | stretch;
}
本文详细介绍了Flex布局,又称弹性盒模型,主要用于移动端小规模布局。Flex布局提供最大的灵活性,包括主轴方向设定、换行方式、对齐方式等。通过flex-direction、flex-wrap、flex-flow、justify-content、align-items和align-content等容器属性,以及order、flex-grow、flex-shrink、flex-basis、flex和align-self等项目属性,可以实现复杂的布局调整。掌握这些属性,能有效提升布局效率和效果。
269

被折叠的 条评论
为什么被折叠?



