弹性盒子 flex-box

弹性盒子

弹性盒子是CSS3的一种新布局模式。CSS3 弹性盒( Flexible Box 或 flexbox),是一种当页面需要适应不同的屏幕大小以及设备类型时确保元素拥有恰当的行为的布局方式。
引入弹性盒布局模型的目的是提供一种更加有效的方式来对一个容器中的子元素进行排列、对齐和分配空白空间。

CSS3 弹性盒子内容

弹性盒子由弹性容器(Flex container)和弹性子元素(Flex item)组成。

弹性容器通过设置 display 属性的值为 flex 或 inline-flex将其定义为弹性容器。

弹性容器内包含了一个或多个弹性子元素。

注意: 弹性容器外及弹性子元素内是正常渲染的。弹性盒子只定义了弹性子元素如何在弹性容器内布局。

弹性子元素通常在弹性盒子内一行显示。默认情况每个容器只有一行。

示例:从左到右


<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>FLEXtitle>
    <style>
        .flex-container {
            display: flex;
            flex-direction: row;
            flex-wrap: wrap;
            width: 1200px;
            height: 640px;
            background-color: lightsteelblue;
        }
        .flex-container .flex-item {
            width: 320px;
            height: 240px;
            margin: 10px;
            background-color:lightsalmon;
        }
    style>
head>
<body>
    <div class="flex-container">
        <div class="flex-item">div>
        <div class="flex-item">div>
        <div class="flex-item">div>
    div>
body>
html>

CSS3 弹性盒子常用属性

属性

  • flex-direction 指定弹性容器中子元素排列方式
  • flex-wrap 设置弹性盒子的子元素超出父容器时是否换行
  • flex-flow flex-direction 和 flex-wrap 的简写
  • align-items 设置弹性盒子元素在侧轴(纵轴)方向上的对齐方式
  • align-content 修改 flex-wrap 属性的行为,类似 align-items, 但不是设置子元素对齐,而是设置行对齐
  • justify-content 设置弹性盒子元素在主轴(横轴)方向上的对齐方式

flex-direction 属性

决定项目的方向。
注意:如果元素不是弹性盒对象的元素,则 flex-direction 属性不起作用。

语法实例

.flex-container { flex-direction: row | row-reverse | column | column-reverse; }
属性值
  • row 默认值。元素将水平显示,正如一个行一样。
  • row-reverse 与 row 相同,但是以相反的顺序。
  • column 元素将垂直显示,正如一个列一样。
  • column-reverse 与 column 相同,但是以相反的顺序。

弹性盒子 flex-box_第1张图片

flex-wrap 属性

flex-wrap 属性规定flex容器是单行或者多行,同时横轴的方向决定了新行堆叠的方向。

  • nowrap 默认值。规定元素不拆行或不拆列。
  • wrap 规定元素在必要的时候拆行或拆列。
  • wrap-reverse 规定元素在必要的时候拆行或拆列,但是以相反的顺序。
.flex-container { flex-wrap: nowrap | wrap | wrap-reverse; }

nowrap (默认):不换行。
弹性盒子 flex-box_第2张图片

wrap:换行,第一行在上方。
弹性盒子 flex-box_第3张图片

wrap-reverse:换行,第一行在下方。
弹性盒子 flex-box_第4张图片

flex-flow 属性

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

.flex-container { flex-flow:   }

align-items属性

align-items 属性定义flex子项在flex容器的当前行的侧轴(纵轴)方向上的对齐方式。

  • stretch 默认值。项目被拉伸以适应容器。
  • center 项目位于容器的中心。
  • flex-start 项目位于容器的开头。
  • flex-end 项目位于容器的结尾。
  • baseline 项目位于容器的基线上。

弹性盒子 flex-box_第5张图片

justify-content属性

justify-content 用于设置或检索弹性盒子元素在主轴(横轴)方向上的对齐方式。

  • flex-start 默认值。项目位于容器的开头。
  • flex-end 项目位于容器的结尾。
  • center 项目位于容器的中心。
  • space-between 项目位于各行之间留有空白的容器内。
  • space-around 项目位于各行之前、之间、之后都留有空白的容器内。

弹性盒子 flex-box_第6张图片

弹性子元素属性

  • order 设置弹性盒子的子元素排列顺序。
  • flex-grow 设置或检索弹性盒子元素的扩展比率。
  • flex-shrink 指定了 flex 元素的收缩规则。flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值。
  • flex-basis 用于设置或检索弹性盒伸缩基准值。
  • flex 设置弹性盒子的子元素如何分配空间。
  • align-self 在弹性子元素上使用。覆盖容器的 align-items 属性。

order属性

.flex-container .flex-item { order: ; }

:用整数值来定义排列顺序,数值小的排在前面。可以为负值,默认为0。

弹性盒子 flex-box_第7张图片

flex-grow属性

.flex-container .flex-item { flex-grow: ; }

:一个数字,规定项目将相对于其他灵活的项目进行扩展的量。默认值是 0。

弹性盒子 flex-box_第8张图片

flex-shrink属性

.flex-container .flex-item { flex-shrink: ; }

:一个数字,规定项目将相对于其他灵活的项目进行收缩的量。默认值是 1。

弹性盒子 flex-box_第9张图片

flex-basis属性

.flex-container .flex-item { flex-basis:  | auto; }

:一个长度单位或者一个百分比,规定元素的初始长度。
auto:默认值。长度等于元素的长度。如果该项目未指定长度,则长度将根据内容决定。

flex属性

flex 属性用于设置或检索弹性盒模型对象的子元素如何分配空间。
flex 属性是 flex-grow、flex-shrink 和 flex-basis 属性的简写属性。

.flex-container .flex-item { flex: flex-grow flex-shrink flex-basis | auto | initial | inherit; }
  • flex-grow 一个数字,规定项目将相对于其他元素进行扩展的量。
  • flex-shrink 一个数字,规定项目将相对于其他元素进行收缩的量。
  • flex-basis 项目的长度。合法值:“auto”、“inherit” 或一个后跟 “%”、“px”、“em” 或任何其他长度单位的数字。
  • auto 与 1 1 auto 相同。
  • none 与 0 0 auto 相同。
  • initial 设置该属性为它的默认值,即为 0 1 auto。
  • inherit 从父元素继承该属性。

align-self属性

.flex-container .flex-item {
   align-self: auto | stretch | center | flex-start | flex-end | baseline | initial | inherit;
}
  • auto 默认值。元素继承了它的父容器的 align-items 属性。如果没有父容器则为 “stretch”。
  • stretch 元素被拉伸以适应容器。
  • center 元素位于容器的中心。
  • flex-start 元素位于容器的开头。
  • flex-end 元素位于容器的结尾。
  • baseline 元素位于容器的基线上。
  • initial 设置该属性为它的默认值。
  • inherit 从父元素继承该属性。

取值同 align-items。

你可能感兴趣的:(弹性盒子 flex-box)