页面布局一直都是web应用样式设计的重点 
我们传统的布局方式都是基于盒模型的 
利用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-wrap
  • justify-content
  • align-items
  • align-content

flex-direction

我们可以使用flex-direction指定主轴的方向,从而改变项目的排列方向 
属性值:

  • row(默认)
  • row-reverse
  • column
  • column-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-wrap
  • wrap
  • wrap-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: 

项目属性

弹性盒布局“项目”有如下属性

  • order
  • flex:flex-grow、flex-shrink、flex-basis
  • align-self

order

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一样,就不多解释了

  • auto
  • stretch
  • flex-start
  • flex-end
  • center
  • baseline
.flex-box {
......
align-items: center;
}
.flex-item:nth-child(2) {
......
align-self: flex-end;
}


弹性盒的全部属性就是这些了 
其实这些都是最新的语法 
在此之前浏览器的实现都不一致,了解一下就好了

    • 2009年规范语法: 
      display: box
    • 2011年非官方规范语法: 
      display: flexbox
    • 最新版本规范语法: 
      display: flex

3.说一下你了解的弹性FLEX布局.的更多相关文章

  1. 弹性FLEX布局

    页面布局一直都是web应用样式设计的重点 我们传统的布局方式都是基于盒模型的 利用display.position.float来布局有一定局限性 比如说实现自适应垂直居中 随着响应式布局的流行,CSS ...

  2. 弹性伸缩布局flex

    Flex 布局教程:语法篇   作者: 阮一峰 日期: 2015年7月10日 网页布局(layout)是CSS的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display属性 + posi ...

  3. CSS3弹性伸缩布局(二)——flex布局

    上一篇博客<CSS3弹性伸缩布局(一)——box布局>介绍了旧版本的box布局,而这篇博客将主要介绍最新版本的flex布局的基础知识. 新版本简介 新版本的Flexbox模型是2012年9 ...

  4. CSS3弹性盒模型,Flex布局教程

    布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中就不容易实现. CSS3中引入flex的弹性盒模型 ...

  5. CSS3弹性伸缩布局(下)——flex布局

    新版本 新版本的flex布局模型是2012年9月提出的工作草案,这个草案是由W3C推出的最新语法,这个版本立志于指定标准,让新式的浏览器全面兼容,在未来的浏览器更新换代中实现统一. 目前几乎大部分的浏 ...

  6. 【flex弹性盒布局】------这个强大的功能

    你知道flex弹性布局么? 我们先来了解它的概念:Flex是Flexible Box的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性. 任何一个容器都可以指定为Flex布局 ...

  7. 弹性伸缩布局-flex

    弹性伸缩布局-flex 引言:本文主要参照阮一峰的网络日志 .郭锦荣的博客总结完成. 正文: 布局的传统解决方案,基于盒状模型,依赖 display 属性 + position属性 + float属性 ...

  8. 学习flex布局(弹性布局)

    Flex是Flexible Box的缩写,意为弹性布局.是W3C早期提出的一个新的布局方案.可以便捷的实现页面布局,目前较高版本的主流浏览器都能兼容,兼容情况如下: Flex在移动端开发上已是主流,比 ...

  9. css基础--深入理解弹性盒flex布局

    欢迎访问我的个人博客:http://www.xiaolongwu.cn 1. 前言 flex弹性盒,是一种布局方式,当页面需要适应不同的屏幕大小以及设备类型时,它依然能确保元素 拥有更恰当的排布行为, ...

随机推荐

  1. Django中间件执行流程

    中间件函数是 django 框架为我们预留的函数接口, 让我们可以干预请求和应答的过程 1. 获取浏览器端的IP地址: 使用 request.META[‘REMOTE_ADDR’] 2. 使用中间件 ...

  2. solr入门之权重排序方法初探之使用edismax改变权重

    做搜索引擎避免不了排序问题,当排序没有要求时,solr有自己的排序打分机制及sorce字段 1.无特殊排序要求时,根据查询相关度来进行排序(solr自身规则) 2.当涉及到一个字段来进行相关度排序时, ...

  3. VC如何得到一个文件夹的路径

    VC中没有现成的函数来选择一个文件夹,但这是经常会用到的,怎么办?自动动手,丰衣足食! 使用SHBrowseForFolder,代码如下: #include   int SelFolder(HWND ...

  4. 关于tcp的三次握手与四次挥手,以及粘包

    tcp三次握手: TCP是因特网中的传输层协议,使用三次握手协议建立连接.当主动方发出SYN连接请求后,等待对方回答SYN+ACK[1],并最终对对方的 SYN 执行 ACK 确认.这种建立连接的方法 ...

  5. Python 中一个逗号引发的悲剧

    遇到一个 Python 字符串的坑,记录一下.看看下面这些代码 >>> a = [ ... 'foo' ... 'bar', ... 'tree' ... ] >>> ...

  6. Hive启动异常

    [root@host ~]# hivewhich: no hbase in (/root/app/apache-maven-3.5.2/bin:/usr/local/sbin:/usr/local/b ...

  7. as2 无法加载类或接口

    1.最大问题就是可能新建文件的时候选择as3的as或者直接复制了as3的as文件过来修改.as文件必须是2的 2.类名是否一致 3.包引用是否正确

  8. WP 8.1 status bar

    A status bar is the bar showing signal, battery and time on the top of the phone's screen. In WP8.1 ...

  9. python, Django 的安装

    yum install zlib yum install zlib-devel yum install openssl-devel 否则导致安装setuptools出错,还需要重新编译python 如 ...

  10. Kafka Manager 监控

    1.安装: 依赖java环境,须首先安装java运行环境,并正确设置路径. 确保kafka已经安装,且版本合适. 修改配置文件:   kafka-manager.zkhosts="你的zoo ...