CSS3 box-flex 弹性盒子布局

本文将从css3 box-flex的属性来讲解弹性布局

所有demo的演示地址https://css-tricks.com/snippets/css/a-guide-to-flexbox/

利用弹性布局五大金刚进行布局的的在线显示

https://xluos.github.io/demo/flexbox/

入门必备 

实现弹性布局必备

第一步:一般的布局首先html代码设置嵌套关系(如果更加复杂就在子div中继续嵌套)

<div id="main">
        <div style="background-color:coral;">A</div>
        <div style="background-color:lightblue;">B</div>
        <div style="background-color:khaki;">C</div>
</div>

 第二步:对于.main父级盒子设置:display:flex   注意不同的浏览器需要兼容前缀如下

dispaly:flex;
display:-webkit-flex;
display:-ms-flex;
display:-moz-flex;
display:-o-flex;

第三步:设置布局方式(在父盒子中设置)

次序等级属性作用盒子描述
1.***flex-direction父盒子指定了弹性容器中子元素的排列方式。
2.1***justify-content父盒子设置弹性盒子元素在主轴(横轴)方向上的对齐方式。
2.2***align-items父盒子设置弹性盒子元素在侧轴(纵轴)方向上的对齐方式。
3.1***flex-wrap父盒子设置弹性盒子的子元素超出父容器时是否换行。
3.2***align-content父盒子修改 flex-wrap 属性的行为,类似align-items, 但不是设置子元素对齐,而是设置行对齐
---flex-flow父盒子flex-direction 和 flex-wrap 的简写
4.1order子盒子设置弹性盒子的子元素排列顺序。
4.2align-self子盒子

在弹性子元素上使用。覆盖容器的 align-items 属性。

定义flex子项单独在侧轴(纵轴)方向上的对齐方式。。

4.2flex子盒子设置弹性盒子的子元素如何分配空间

常用的5个属性justify-content:center;align-items:center)垂直水平居中 

CSS3 弹性盒子属性


浮动布局诞生时只是为了图文快排,并不是为了块状布局,flex-box是专门为块级布局而诞生的

display:flex和flex-direction

display:flex;指定当前盒子为弹性盒子

flex-direction:改变主轴的方向//写在当前盒子中而不是子盒子中

row:       X轴 从左向右

row-reverse:       X轴 从右向左

column:       Y轴 从上向下

column-reverse:    Y轴 从下向上

描述实例
row默认值。灵活的项目将水平显示,正如一个行一样。尝试一下 »
row-reverse与 row 相同,但是以相反的顺序。尝试一下 »
column灵活的项目将垂直显示,正如一个列一样。尝试一下 »
column-reverse与 column 相同,但是以相反的顺序。尝试一下 »
initial设置该属性为它的默认值。请参阅 initial尝试一下 »
inherit从父元素继承该属性。请参阅 inherit

flex-wrap 伸缩容器

这里所谓的拆行换行,指的是div的总长度,与子div内部无直接关系

属性值

描述
nowrap默认值。规定灵活的项目不拆行或不拆列。
wrap规定灵活的项目在必要的时候拆行或拆列。
wrap-reverse规定灵活的项目在必要的时候拆行或拆列,但是以相反的顺序。
initial设置该属性为它的默认值。请参阅 initial
inherit从父元素继承该属性。请参阅 inherit

 

flex-flow :flex-direction和flex-wrap的缩写方式

 flex-flow:flex-direction||flex-wrap

order:(针对子盒子)设置弹性盒对象元素的顺序

.a1 {order:2;}
			
			.a2 {order:1;}
			.a3 {order:3;}

 

justify-content、aign-items和align-self

justify-content(针对父盒子)

  伸缩容器---在X轴对齐方式

描述测试
flex-start默认值。项目位于容器的开头。左对齐测试 »
flex-end项目位于容器的结尾。右对齐测试 »
center项目位于容器的中心。居中测试 »
space-between项目位于各行之间留有空白的容器内。 X轴上均匀分布      只限于子盒子之间测试 »
space-around项目位于各行之前、之间、之后都留有空白的容器内。 Y轴上均匀分布   包括子盒子之间和父盒子两边测试 »
initial设置该属性为它的默认值。请参阅 initial测试 »
inherit从父元素继承该属性。请参阅 inherit 

aign-items (针对父盒子)

伸缩容器  控制伸缩项在Y轴对齐方式

描述测试
stretch默认。 拉伸元件以适应容器。测试 »
center中心元素在容器内。测试 »
flex-start位置元素在容器的开头。测试 »
flex-end位置元素在容器的末端。测试 »
baseline位置元素在容器的基线。测试 »
initial设置为默认值。请参阅 initial测试 »
inherit从其父元素继承此属性。请参阅 inherit

align-self 伸缩项(针对子盒子) 

 控制指定伸缩项在Y轴的展现方式  只有设置了父盒子的Y轴对齐方式 align-items之后才会生效

auto默认值。元素继承了它的父容器的 align-items 属性。如果没有父容器则为 "stretch"。测试 »
stretch元素被拉伸以适应容器。当其子盒子没有设置固定高度才有效测试 »
center元素位于容器的中心。测试 »
flex-start元素位于容器的开头。测试 »
flex-end元素位于容器的结尾。测试 »
baseline元素位于容器的基线上。测试 »
initial设置该属性为它的默认值。请参阅 initial测试 »
inherit从父元素继承该属性。请参阅 inherit

 

align-content(针对父盒子)

 

align-content:控制伸缩项所组成的行列(伸缩行列)在Y轴的展现方式只有一行或列不生效

 

描述测试
stretch默认值。项目被拉伸以适应容器。测试 »
center项目位于容器的中心。测试 »
flex-start项目位于容器的开头。测试 »
flex-end项目位于容器的结尾。测试 »
space-between项目位于各行之间留有空白的容器内。测试 »
space-around项目位于各行之前、之间、之后都留有空白的容器内。测试 »
initial设置该属性为它的默认值。请参阅 initial测试 »
inherit从父元素继承该属性。请参阅 inherit 

 

 flex-grow 、flex-shrink、basis

flex-grow

控制伸缩项在伸缩行的伸展程度

属性值

描述
number一个数字,规定项目将相对于其他灵活的项目进行扩展的量。默认值是 0。
initial设置该属性为它的默认值。请参阅 initial
inherit从父元素继承该属性。请参阅 inherit

 

flex-shrink (针对子盒子)

属性:用于设置或检索弹性盒的收缩比率。针对Y轴方向,没有设置高的情况下有效。

注意:如果元素不是弹性盒对象的元素,则 flex-shrink 属性不起作用。

属性值

描述
number一个数字,规定项目将相对于其他灵活的项目进行收缩的量。默认值是 0。flex-shrink: 3;表示占据1/3
initial设置该属性为它的默认值。请参阅 initial
inherit从父元素继承该属性。请参阅 inherit

 flex-basis

 

属性值

描述
number一个长度单位或者一个百分比,规定灵活项目的初始长度。
auto默认值。长度等于灵活项目的长度。如果该项目未指定长度,则长度将根据内容决定。
initial设置该属性为它的默认值。请参阅 initial
inherit从父元素继承该属性。请参阅 inherit

 flex 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值