页面布局一直都是%ignore_a_1%应用样式设计的重点我们传统的布局方式都是基于盒模型的利用display、position、float来布局有一定局限性比如说实现自适应垂直居中随着响应式布局的流行,CSS3引入了更加灵活的弹性布局模型
flex弹性布局
使用弹性布局可以有效的分配一个容器的空间即使我们的容器元素尺寸改变它内部的元素也可以调整它的尺寸来适应空间
若想让一个元素变成弹性盒很简单
.demo { /*块级元素*/ display: flex; }
.demo { /*行级元素*/ display: inline-flex; }
设置了flex布局后,子元素的float、clear和vertical-align属性就会失效
举个小例子
<div class=\"flex-box\"> <div class=\"flex-item\">1</div> <div class=\"flex-item\">2</div> <div class=\"flex-item\">3</div> </div>
.flex-box { width: 500px; height: 100px; border: 1px solid black; } .flex-item { width: 100px; height: 100px; font-size: 80px; line-height: 100px; text-align: center; } .flex-item:nth-child(1) { background-color: lightseagreen; } .flex-item:nth-child(2) { background-color: violet; } .flex-item:nth-child(3) { background-color: cornflowerblue; }
正常情况下,子元素div默认占满一行,所以他们只能纵向排列
现在我们使用弹性布局
.flex-box { display: flex; /*增*/ width: 500px; height: 100px; border: 1px solid black; }
我们发现子元素在父元素中呈现行排列看起来好像子元素应用了浮动float但这个属性远远没有这么简单现在才刚刚开始(⊙▽⊙)
相关概念
在讲那些属性之前,我们先来看一些基本概念设置了flex布局的元素,称为“flex容器”,简称“容器”它的子元素,称为“flex项目”,简称“项目”这里我引入一张图(原谅我的盗图,自己懒得画了..)
“容器”中有两条垂直的坐标轴横向的叫做主轴纵向的叫做交叉轴主轴左边与右边分别叫做主轴起点与主轴终点交叉轴上边与下边分别叫做交叉轴起点与交叉轴终点
“项目”也有两个名词每个项目的宽与高叫做主轴尺寸与交叉轴尺寸
这回我们就能理解了为什么使用弹性布局后子元素呈现行排列项目在容器中就是沿着主轴排列的
容器属性
弹性盒布局“容器”有如下属性
flex-flow:flex-direction,flex-wrapjustify-contentalign-itemsalign-contentflex-direction
我们可以使用flex-direction指定主轴的方向,从而改变项目的排列方向属性值:
row(默认)row-reversecolumncolumn-reverse
.flex-box { display: flex; width: 500px; height: 100px; border: 1px solid black; flex-direction: row-reverse; /*增*/ }
其他属性也不多解释了,很好理解
这张图片分别对应了column-reverse、column、row、row-reverse
flex-wrap
我们弹性盒的项目默认都是排列在一个轴上的这样如果项目多的话,会“弹性”压缩在一行比如说我多加一些项目
我并没有改变项目的宽但是由于处于弹性盒中项目过多,项目在主轴上被压缩
现在添加flex-wrap属性
.flex-box { ...... flex-wrap: wrap; /*增*/ }
flex-wrap: wrap可以让我们指定当容器“装不下”项目时,是否换行属性值如下:
no-wrapwrapwrap-reverse
前两个我们都理解了第三个属性值wrap-reverse换行的项目会排在上面像这样
flex-flow
flex-flow是flex-direction和flex-wrap的复合属性两个属性都是必写的就不多解释了
justify-content
justify-content属性定义了项目在主轴上的对齐方式属性值如下:
flex-start:左对齐(默认)flex-end:右对齐center:居中space-between:两端对齐(项目间间隔相同)space-around:两端间隔对齐(项目间间隔是项目与边框间隔的2倍)
flex-start :
flex-end:
center:
space-between:
space-around:
align-items
align-items属性定义项目在交叉轴上如何对齐属性值如下:
stretch:未设置高度(或height: auto)的项目占满整个容器高度(默认)flex-start :交叉轴起点对齐flex-end:交叉轴终点对齐center:交叉轴中点对齐baseline:项目第一行文字的基线对齐
flex-start:
flex-end:
center:
baseline:
align-content
align-content属性定义多根轴线的对齐方式这个属性只有在容器有多条主轴是才有效,一条主轴无效类似于justify-content属性属性值如下:
stretch:轴线占满整个交叉轴(默认值)flex-start:与交叉轴的起点对齐flex-end:与交叉轴的终点对齐center:与交叉轴的中点对齐space-between:与交叉轴两端对齐,轴线间间隔相等space-around:每根轴线两侧的间隔都相等
flex-start:
flex-end:
center:
space-between:
space-around:
项目属性
弹性盒布局“项目”有如下属性
orderflex:flex-grow、flex-shrink、flex-basisalign-selforder
order允许我们自定义项目的排列顺序默认为0,属性值是数字,数值越小越靠前有点类似我们优先队列中的优先级
.flex-item:nth-child(1) { ...... order: 99; } .flex-item:nth-child(2) { ...... order: -1; } .flex-item:nth-child(3) { ...... }
flex-grow
flex-grow定义项目的放大比例默认是0,就是如果没有占满容器整行,也不放大项目,就像上面的图片
.flex-item:nth-child(1) { ...... flex-grow: 1; <-- } .flex-item:nth-child(2) { ...... flex-grow: 2; <-- } .flex-item:nth-child(3) { ...... flex-grow: 3; <-- }
这就相当于三个项目把剩下的空间“切成”6块项目一拿走1块,项目二拿走2块,项目三拿走3块
flex-shrink
flex-shrink定义项目的缩小比例默认是1,就是如果空间不足,该项目将等比缩小通过这个属性我们可以控制各个项目缩小的比例
.flex-item:nth-child(1) { ...... flex-shrink: 1; <-- } .flex-item:nth-child(2) { ...... flex-shrink: 2; <-- } .flex-item:nth-child(3) { ...... flex-shrink: 3; <-- }
这样各个项目缩小的比例就是 1:2:3从而保证所有项目总宽度和容器宽度相等
flex-basis
flex-basis定义在分配多余空间之前,项目占据的主轴空间默认auto,就是项目本来的宽度我们可以手动设置长度
.flex-item:nth-child(1) { ...... flex-basis: 150px; <-- } .flex-item:nth-child(2) { ...... } .flex-item:nth-child(3) { ...... }
flex
flex是flex-grow、flex-shrink、flex-basis的复合属性默认值:0 1 auto,后两个属性可选可以写关键字:auto (1 1 auto) 和 none (0 0 auto)
align-self
align-self属性允许个别项目拥有与众不同的对齐方式就是会覆盖align-items设置的对齐属性默认值auto,继承弹性容器的align-items属性值属性值除了auto外,和align-items一样,就不多解释了
autostretchflex-startflex-endcenterbaseline
.flex-box { ...... align-items: center; } .flex-item:nth-child(2) { ...... align-self: flex-end; }
http://www.dengb.com/HTML_CSS/1352110.htmlwww.dengb.comtruehttp://www.dengb.com/HTML_CSS/1352110.htmlTechArticle弹性FLEX布局, 页面布局一直都是web应用样式设计的重点 我们传统的布局方式都是基于盒模型的 利用display、position、float来布局有一定局限…
—-想了解更多的css相关样式处理怎么解决关注