任何一个容器都可以指定为flex布局;

行内元素也可以使用flex布局;

设为flex布局以后,子元素的float,clear,vertical-align属性都将失效;

flex容器的属性:

 flex-direction
flex-wrap
flex-flow
justify-content
align-items
align-content

flex-direction属性:

//flex-direction属性决定主轴的方向;

.box{
flex-direction:row //row(默认值):主轴为水平方向,起点在左端。
}
.box{
flex-direction:row-reverse://主轴为水平方向,起点在右端。
}
.box{
flex-direction:column; //主轴方向为垂直方向,起点在上沿;
}
.box{
flex-direction:column-reverse; //主轴方向为垂直方向,起点在下沿
}

flex-wrap:属性:默认情况下,item都排列在一条线上,flex-wrap定义,如果一条轴线排不下,该如何换行;

 .box{
flex-wrap:no-wrap;(默认)不换行
}
.box{
flex-wrap:wrap; //换行,第一行在上方;
}
.box{
flex-wrap:wrap-reverse;//换行;第二行在上方;
}

flex-flow:是flex-direction和flex-wrap的缩写,默认为row nowrap;

.box{
flex-flow:<flex-direction> ||<flex-wrap>
}

justify-content:定义item在主轴上的对齐方式;

.box{
justify-content:flex-start;//从左向右依次排列
}
.box{
justify-content:flex-end;//从又向左依次排列
}
.box{
justify-content:center;居中排列
}
.box{
justify-content:space-between;//两端对齐,项目之间的间隔都相等。
}
.box{
justify-content:space-around;每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。}

align-items:item在纵轴上的对齐方式:属性如下图:

flex-start:交叉轴的起点对齐。
flex-end:交叉轴的终点对齐。
center:交叉轴的中点对齐。
baseline: 项目的第一行文字的基线对齐。
stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。

align-content:定义了多跟轴线的对齐方式;如果该项目只有一根轴线,该属性不起作用;

.box {
align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}

flex-start:与交叉轴的起点对齐。
flex-end:与交叉轴的终点对齐。
center:与交叉轴的中点对齐。
space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。
space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。
stretch(默认值):轴线占满整个交叉轴。

项目item的属性:

  

order
flex-grow
flex-shrink
flex-basis
flex
align-self
//order属性:定义项目的排列顺序,数值越小,排列越靠前,默认为0;
.item{
order:<integer>
>

flex-grow 定义item的放大比例,默认为0;即即使存在剩余空间也不放大;
.item{
flex-grow:<number>
}

如果所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话)。如果一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍。

flex-shrink:定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小;

.item {
flex-shrink: <number>; /* default 1 */
}

如果所有项目的flex-shrink属性都为1,当空间不足时,都将等比例缩小。如果一个项目的flex-shrink属性为0,其他项目都为1,则空间不足时,前者不缩小。

负值对该属性无效。

flex-basis:定义了在分配多余空间前,项目占据的主轴空间;默认为auto;即项目本来的大小;

.item{
flex-basis:<length> | auto;
>

它可以设为跟widthheight属性一样的值(比如350px),则项目将占据固定空间。

flex属性是flex-grow,flex-shrink,flex-basis的简写,默认为0 1 aauto;后两个可选;

.item {
flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
}

align-self:属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性,默认值为auto,表示集成父元素的align-items属性,如果没有父元素,则等同于stretch;

该属性可能取6个值,除了auto,其他都与align-items属性完全一致。

flex布局知识点(阮一峰博客)的更多相关文章

  1. xargs命令学习,于阮一峰博客

    一.标准输入与管道命令 Unix 命令都带有参数,有些命令可以接受"标准输入"(stdin)作为参数. $ cat /etc/passwd | grep root 上面的代码使用了 ...

  2. javascript工具--控制台详解(转自 阮一峰博客)

    大神这篇博客是写在2011年,主要介绍 “Firefox” 浏览器插件 “Firebug” 的操作,如今主流浏览器对控制台都已经提供了很好的支持.我自己用的最多是谷歌的 “chrome” 浏览器,下面 ...

  3. 阮一峰博客里面css3的display:flex的布局

  4. 跨域资源共享 CORS 详解(转自阮一峰博客)

    CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing). 它允许浏览器向跨源服务器,发出XMLHttpRequest请求,从 ...

  5. OAuth2.0的理解-转自阮一峰博客

    一.应用场景 为了理解OAuth的适用场合,让我举一个假设的例子. 有一个"云冲印"的网站,可以将用户储存在Google的照片,冲印出来.用户为了使用该服务,必须让"云冲 ...

  6. flex实例(阮一峰)

    Flex 布局教程:实例篇   作者: 阮一峰 日期: 2015年7月14日 上一篇文章介绍了Flex布局的语法,今天介绍常见布局的Flex写法. 你会看到,不管是什么布局,Flex往往都可以几行命令 ...

  7. flex布局知识点

    flexBox 布局最合适小规模布局,而网格布局适合较大规模布局. float,clear,vertical-align  在flex中不起作用. flex布局中,有两类作用于父节点也子节点的样式,大 ...

  8. Flex 布局知识点梳理

    传统的布局方案,在针对特殊布局时会很不方便,比如垂直居中,把一个容器等分为N列等等.自从 Flex 出现以后,这些都迎刃而解了,本文对Flex相关内容做一个简单梳理. 什么是 Flex Flex 是 ...

  9. 韩天峰博客 php基础知识学习记录

    http://rango.swoole.com 写好PHP代码真的不容易,给大家几个建议: 慎用全局变量,全局变量不好管理的,会导致你的代码依赖于全局变量,而耦合度太高. 一定不要复制粘贴代码,可重用 ...

随机推荐

  1. null的数据类型

    Oracle的NULL代表的含义是不确定,那么不确定的东西也会有确定的数据类型吗?或者换个说法,NULL在Oracle中的默认数据类型是什么,下面就来探讨这个问题. 首先公布答案,NULL的默认类型是 ...

  2. HDUOJ-----Computer Transformation

    Computer Transformation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/ ...

  3. 使用Java调用JS

    import junit.framework.TestCase; import javax.script.ScriptEngine; import javax.script.ScriptEngineM ...

  4. [抄]OKR

    OKR是Objective Key Result KPI是KeyPointIndicator OKR概览 OKR是一个目标管理工具.即目标与关键成果法,是一套明确和跟踪目标及其完成情况的管理工具和方法 ...

  5. 【DeepLearning】用于几何匹配的卷积神经网络体系结构

    [论文标题]Convolutional neural network architecture for geometric matching (2017CVPR) [论文作者]Ignacio Rocc ...

  6. 程序员,不要让自己做兔子(updated) 网上最近流传的一个笑话,关于兔子,狼还有一只老虎的,故事 我就是想打你了,还需要什么理由吗?谁让你是兔子 项目经理是这样当的

    程序员,不要让自己做兔子(updated) 前段时间和一个朋友聊天,酒席间向我抱怨他那段时间的郁闷:项目经理从客户那里拿来一个需求,实际上就是一个ppt描述,我这个朋友拿过来看后刚开始不觉得什么,一个 ...

  7. HDU 2227 Find the nondecreasing subsequences (数状数组)

    Find the nondecreasing subsequences Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/3 ...

  8. 站在.NET的角度学安卓的草民笔记1

    Java           ->        .NET 安卓          ->        winform/WPF 类继承Activity  ->     类继承 For ...

  9. 创建一个已经存在数据的MySQL复制

    1.配置master库必须开启二进制日志和分配唯一的server id·如果没设置server-id或将其设置为0,master节点会拒绝slave的连接·建议在master节点设置innodb_fl ...

  10. C++栈学习——顺序栈和链栈的差别

    C++中栈有顺序栈和链栈之分.在顺序栈中,定义了栈的栈底指针(存储空间首地址base).栈顶指针top以及顺序存储空间的大小stacksize(个人感觉这个数据成员是能够不用定义的) //顺序栈数据结 ...