详解CSS3实现弹性布局的方式
一、CSS3弹性盒子
弹性盒子是CSS3的一种新规划模式。
CSS3 弹性盒( Flexible Box 或 flexbox),是一种当页面需要顺应不一样的屏幕大小乃至设备类型时确保元素具有适当的行动的规划方式。
引入弹性盒规划模型的目的是供给一种愈加有效的方式来对一个容器中的子元素停止摆列、对齐和分配空白空间。
二、阅读器支撑
表格中的数字表示支撑该属性的第一个阅读器的版本号。
紧跟在数字后面的 -webkit- 或 -moz- 为指定阅读器的前缀。
属性 | |||||
Basic support (single-line flexbox) | 29.0 21.0 -webkit- | 11.0 | 22.0 18.0 -moz- | 6.1 -webkit- | 12.1 -webkit- |
Multi-line flexbox | 29.0 21.0 -webkit- | 11.0 | 28.0 | 6.1 -webkit- | 17.0 15.0 -webkit- 12.1 |
三、CSS3 弹性盒子内容
弹性盒子由弹性容器(Flex container)和弹性子元素(Flex item)组成。
弹性容器通过设定 display 属性的值为 flex 或 inline-flex将其定义为弹性容器。
弹性容器内包括了一个或多个弹性子元素。
留意: 弹性容器外及弹性子元素内是正常渲染的。弹性盒子只定义了弹性子元素怎样在弹性容器内规划。
弹性子元素平常在弹性盒子内一行显示。默许状况每个容器只要一行。
以下元素展现了弹性子元素在一行内显示,从左到右:
<!DOCTYPE html> <html> <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> <div></div> <div></div> <div></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 | 设定弹性盒子的子元素怎样分配空间。 |
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。
参照
阮一峰教师·Flex规划教程
runoob·Flex规划
本文转载自:https://www.jianshu.com/p/5856c4ae91f2
相关引荐:CSS视频教程
以上就是详解CSS3实现弹性规划的方式的具体内容,更多请关注百分百源码网其它相关文章!