CSS3弹性盒布局⽅式
⼀、CSS3弹性盒⼦
弹性盒⼦是CSS3的⼀种新布局模式。
CSS3 弹性盒( Flexible Box 或 flexbox),是⼀种当页⾯需要适应不同的屏幕⼤⼩以及设备类型时确保元素拥有恰当的⾏为的布局⽅式。引⼊弹性盒布局模型的⽬的是提供⼀种更加有效的⽅式来对⼀个容器中的⼦元素进⾏排列、对齐和分配空⽩空间。
⼆、浏览器⽀持
表格中的数字表⽰⽀持该属性的第⼀个浏览器的版本号。
紧跟在数字后⾯的 -webkit- 或 -moz- 为指定浏览器的前缀。
属性
Basic support (single-line flexbox)29.0 21.0 -webkit-11.022.0 18.0 -moz-6.1 -webkit-12.1 -webkit-
Multi-line flexbox29.0 21.0 -webkit-11.028.0  6.1 -webkit-17.0 15.0 -webkit- 12.1
三、CSS3 弹性盒⼦内容
弹性盒⼦由弹性容器(Flex container)和弹性⼦元素(Flex item)组成。
弹性容器通过设置 display 属性的值为 flex 或 inline-flex将其定义为弹性容器。
弹性容器内包含了⼀个或多个弹性⼦元素。
注意:弹性容器外及弹性⼦元素内是正常渲染的。弹性盒⼦只定义了弹性⼦元素如何在弹性容器内布局。
弹性⼦元素通常在弹性盒⼦内⼀⾏显⽰。默认情况每个容器只有⼀⾏。
以下元素展⽰了弹性⼦元素在⼀⾏内显⽰,从左到右:
<!DOCTYPE html>
<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>FLEX</title>
<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设置弹性盒⼦元素在主轴(横轴)⽅向上的对齐⽅式
1. flex-direction 属性
决定项⽬的⽅向。
注意:如果元素不是弹性盒对象的元素,则 flex-direction 属性不起作⽤。
.flex-container { flex-direction: row | row-reverse | column | column-reverse; }
属性值
值描述
row默认值。元素将⽔平显⽰,正如⼀个⾏⼀样。
row-reverse与 row 相同,但是以相反的顺序。
column元素将垂直显⽰,正如⼀个列⼀样。
column-reverse与 column 相同,但是以相反的顺序。
2. flex-wrap 属性
flex-wrap 属性规定flex容器是单⾏或者多⾏,同时横轴的⽅向决定了新⾏堆叠的⽅向。
值描述
nowrap默认值。规定元素不拆⾏或不拆列。
wrap规定元素在必要的时候拆⾏或拆列。
wrap-reverse规定元素在必要的时候拆⾏或拆列,但是以相反的顺序。
.flex-container { flex-wrap: nowrap | wrap | wrap-reverse; }
可以取三个值:
(1) nowrap (默认):不换⾏。
(2)wrap:换⾏,第⼀⾏在上⽅。
(3)wrap-reverse:换⾏,第⼀⾏在下⽅。
3. flex-flow 属性
flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。
.flex-container { flex-flow: <flex-direction> <flex-wrap> }
4. align-items属性
align-items 属性定义flex⼦项在flex容器的当前⾏的侧轴(纵轴)⽅向上的对齐⽅式。
值描述
stretch默认值。项⽬被拉伸以适应容器。
center项⽬位于容器的中⼼。
flex-start项⽬位于容器的开头。
flex-end项⽬位于容器的结尾。
baseline项⽬位于容器的基线上。
5. justify-content属性
justify-content ⽤于设置或检索弹性盒⼦元素在主轴(横轴)⽅向上的对齐⽅式。
值描述
flex-start默认值。项⽬位于容器的开头。
flex-end项⽬位于容器的结尾。
center项⽬位于容器的中⼼。
space-between项⽬位于各⾏之间留有空⽩的容器内。
space-around项⽬位于各⾏之前、之间、之后都留有空⽩的容器内。
五、弹性⼦元素属性
属性描述
order设置弹性盒⼦的⼦元素排列顺序。
flex-grow设置或检索弹性盒⼦元素的扩展⽐率。
flex-shrink指定了 flex 元素的收缩规则。flex 元素仅在默认宽度之和⼤于容器的时候才会发⽣收缩,其收缩的⼤⼩是依据 flex-shrink 的值。flex-basis⽤于设置或检索弹性盒伸缩基准值。
flex设置弹性盒⼦的⼦元素如何分配空间。
常用css布局align-self在弹性⼦元素上使⽤。覆盖容器的 align-items 属性。
1. order属性
.flex-container .flex-item { order: <integer>; }
<integer>:⽤整数值来定义排列顺序,数值⼩的排在前⾯。可以为负值,默认为0。
2. flex-grow属性
.flex-container .flex-item { flex-grow: <integer>; }
<integer>:⼀个数字,规定项⽬将相对于其他灵活的项⽬进⾏扩展的量。默认值是 0。
3. flex-shrink属性
.flex-container .flex-item { flex-shrink: <integer>; }
<integer>:⼀个数字,规定项⽬将相对于其他灵活的项⽬进⾏收缩的量。默认值是 1。
4. flex-basis属性
.flex-container .flex-item { flex-basis: <integer> | auto; }
<integer>:⼀个长度单位或者⼀个百分⽐,规定元素的初始长度。
auto:默认值。长度等于元素的长度。如果该项⽬未指定长度,则长度将根据内容决定。
5. 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从⽗元素继承该属性。
6. 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。