Skip to content

flex 弹性布局

属性概览

flex容器的属性

css
.flex-container {
  /*主轴的方向*/
  flex-direction: row | row-reverse | column | column-reverse;
  /*换行*/
  flex-wrap: nowrap | wrap | wrap-reverse;
  /*flex-direction flex-wrap 简写*/
  flex-flow: <flex-direction> <flex-wrap>;
  /*子元素在主轴上的对齐方式*/
  justify-content: flex-start | flex-end | center | space-between | space-around;
  /*子元素在交叉轴上的对齐方式*/
  align-items: flex-start | flex-end | center | baseline | stretch;
  /*多根轴线的对齐方式*/
  align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}

flex容器子元素的属性

css
 .flex-item {
  /*子元素的排列顺序*/
  order: <integer>;
  /*子元素的放大比例*/
  flex-grow: <number>; /* default 0 */
  /*子元素的缩小比例*/
  flex-shrink: <number>; /* default 1 */
  flex-basis: <length> | auto; /* default auto */
  /*flex-grow flex-shrink 简写*/
  flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ];
  /*单个子元素与其他子元素不一样的对齐方式*/
  align-self: auto | flex-start | flex-end | center | baseline | stretch;
}

flex-direction(flex容器)

flex-direction属性决定主轴的方向(即项目的排列方向)

css
.box {
  flex-direction: row | row-reverse | column | column-reverse;
}
  • row(默认值):主轴为水平方向,起点在左端。

    f9d2d063-9f9e-430e-8446-fffb1a3cfda0.png

  • row-reverse:主轴为水平方向,起点在右端。

    b2125700-b67d-4734-8bf6-d53ad43d9738.png

  • column:主轴为垂直方向,起点在上沿。

    21be9c80-b73e-4996-bfa0-d282a0e671e3.png

  • column-reverse:主轴为垂直方向,起点在下沿。

    ccb73f3b-b0c0-4327-97bb-4631cf1cf847.png

flex-wrap(flex容器)

flex-wrap属性定义当一条轴线排不下时如何换行

css
.box{
  flex-wrap: nowrap | wrap | wrap-reverse;
}
  • nowrap(默认):不换行。

    a8590ac1-fa2d-4a8b-9beb-b9976ffd79f1.png

  • wrap:换行,第一行在上方。

    c957f410-6efc-4b83-96c2-833ae754c401.png

  • wrap-reverse:换行,第一行在下方。

    0dbe5963-9f7b-48e4-b5be-7590d8483427.png

flex-flow(flex容器)

flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap

css
.box {
  flex-flow: <flex-direction> <flex-wrap>;
}

justify-content(flex容器)

justify-content属性定义了项目在主轴上的对齐方式

css
.box {
  justify-content: flex-start | flex-end | center | space-between | space-around;
}
  • flex-start(默认值):左对齐

    37b97d63-e7d6-4949-99b6-847f48b1d185.png

  • flex-end:右对齐

    d006a993-23f4-405d-8a0a-699f76c2fd3a.png

  • center: 居中

    646c3b36-5d34-433a-9a7a-b40a4efef4c5.png

  • space-between:两端对齐,项目之间的间隔都相等。

    b78f07f9-e565-45a1-a4e2-44c0ca5154e2.png

  • space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。

    8abb1474-3119-454d-bb60-49ce1e4b29ca.png

align-items(flex容器)

align-items属性定义项目在交叉轴上如何对齐

css
.box {
  align-items: flex-start | flex-end | center | baseline | stretch;
}
  • flex-start:交叉轴的起点对齐。

    dacf9d03-c253-4e6e-b4c2-421609f8ded9.png

  • flex-end:交叉轴的终点对齐。

    9401fcc5-8735-49b0-a425-e22b042f1274.png

  • center:交叉轴的中点对齐。

    d46624a2-d612-4d11-8e14-74ab696d41a9.png

  • baseline: 项目的第一行文字的基线对齐。

    86cebf20-ea81-4d5d-ae4d-9ed8b903331a.png

  • stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。

    e01f9487-4d74-49e9-ad28-a830f8c7957c.png

align-content(flex容器)

align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用

css
.box {
  align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}
  • flex-start:与交叉轴的起点对齐。

    ce7b36a8-7214-4f89-b823-f5dc0be18c51.png

  • flex-end:与交叉轴的终点对齐。

    5f6b512e-3da0-402c-9344-b29763cacd65.png

  • center:与交叉轴的中点对齐。

    e62e6e0f-9d71-47f8-a6e8-3f855e559048.png

  • space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。

    dcf78e9a-fbd8-40e0-8291-906ad11f8da8.png

  • space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。

    c01da725-1f5b-4550-8396-fc36507a2721.png

  • stretch(默认值):轴线占满整个交叉轴。

order(flex容器的子元素)

order属性定义子元素的排列顺序。数值越小,排列越靠前,默认为0。

css
.item {
  order: <number>;
}

545b01f0-fde8-483b-9b02-c1674fe1409e.png

flex-grow(flex容器的子元素)

flex-grow属性定义子元素的放大比例,默认为0,即如果存在剩余空间,也不放大。

如果所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话)。

如果一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍。

css
.item {
  flex-grow: <number>; /* default 0 */
}

0370f429-8a0e-42b2-8c1e-f1675a93d36d.png

flex-shrink(flex容器的子元素)

flex-shrink属性定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。

负值对该属性无效。

如果所有项目的flex-shrink属性都为1,当空间不足时,都将等比例缩小。

如果一个项目的flex-shrink属性为0,其他项目都为1,则空间不足时,前者不缩小。

css
.item {
  flex-shrink: <number>; /* default 1 */
}

f98623bc-3f47-4f43-bd33-ecc27a039cbb.png

flex-basis(flex容器的子元素)

flex-basis属性定义了在分配多余空间之前,项目占据的主轴空间。

浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项目的本来大小。

它可以设为跟width或height属性一样的值(比如350px),则项目将占据固定空间。

css
.item {
  flex-basis: <length> | auto; /* default auto */
}

flex(flex容器的子元素)

flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto,后两个属性可选。

该属性有两个快捷值:auto (1 1 auto) 和 none (0 0 auto)。

建议优先使用这个属性,而不是单独写三个分离的属性,因为浏览器会推算相关值。

css
.item {
  flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
}

align-self

align-self属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。

默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。

该属性可能取6个值,除了auto,其他都与align-items属性完全一致。

css
.item {
  align-self: auto | flex-start | flex-end | center | baseline | stretch;
}

220a88e7-8577-4374-b924-8a92b1a8ecec.png

最近更新:10/11/2024, 5:05:09 AM

原文链接:flex 弹性布局

|下一篇:Dockerfile语法