传统的 CSS 布局方式是基于盒模型(它是根据盒子与父盒子以及兄弟盒子的关系确定大小位置的算法),实现时依赖于 block, inline, table, position, float 这些属性,但对于一些特殊布局不易实现,比如垂直居中

Flexbox Layout 是一种新的布局方式,被称为弹性布局,它使得子元素(items)可以灵活的、响应式的适应父容器(flex container)的空间,即使子元素的大小未知或是动态,并且可以很容易实现元素的水平和垂直对齐。

盒模型是基于 blockinline 的流动方向进行布局,而 flex 布局则是基于弹性流方向(flex-flow directions),基本思想如下图所示。

flex 容器内的子元素会沿着 main axis(从 main-startmain-end )或 cross axis(从 cross-startcross-end)进行布局,其中:

  • main axis - 主轴,子元素排列的基本轴,要注意,它不一定是水平的,这取决于 flex-direction 属性的配置
  • main-start | main-end - 子元素从 main-start 开始到 main-end 弹性的放置在容器中,默认都在一行排列,不换行, 除非设置 flex-wrap 属性
  • main size - 子元素的主尺寸,如果主轴是水平的,那 width 是主尺寸;垂直的,那 height 是主尺寸
  • cross axis - 垂直于主轴的轴,称之为交叉轴,方向取决于主轴的方向
  • cross-start | cross-end - 当子元素换行时,每行则从 cross-start 开始到 cross-end 排列
  • cross size - 与 main size 同理,只不过刚好相反

Flex Container

使用以下代码就可以将一个 HTML 元素指定为 flex 布局:

.container {
display: flex; /* or inline-flex */
}

这个元素称为 Flex Container,内部其他 HTML 元素被称为 Flex Itemsflex 容器 有 6 个属性:

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

flex-direction

确定主轴的方向,也就是内部元素的弹性排列方向。如果不考虑换行,Flexbox 是单向布局的概念,始终将元素放置在水平行垂直列中。

.container {
flex-direction: row | row-reverse | column | column-reverse;
}
  • row(默认): 主轴为水平方向,从左到右排列
  • row-reverse: 主轴为水平方向,从右到左排列
  • column: 主轴为垂直方向,从上到下排列
  • column-reverse: 主轴为垂直方向,从下到上排列

flex-wrap

默认情况下,子元素不会换行,只会在同一行(或列)中放置,可以使用此属性设置换行

.container{
flex-wrap: nowrap | wrap | wrap-reverse;
}
  • nowrap (默认): 不换行
  • wrap: 换行,第一行在上方
  • wrap-reverse: 换行,第一行在下方

flex-flow

它是 flex-direction 和 flex-wrap 属性的缩写.

flex-flow: <'flex-direction'> || <'flex-wrap'>

默认是: flex-flow: row nowrap

justify-content

定义子元素在主轴上的对齐方式

.container {
justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly;
}
  • flex-start (默认): 左对齐,以主轴的起点对齐
  • flex-end: 右对齐,以主轴的终点对齐
  • center: 居中,以主轴的中点对齐
  • space-between: 两端对齐,子元素间隔相等
  • space-around: 子元素两侧的间隔相等,因此,元素之间的间隔正好是与边框间隔的两倍
  • space-evenly: 子元素分布排列,并且两个元素的间隔与到边框的间隔相等

align-items

定义子元素在交叉轴上如何对齐

.container {
align-items: stretch | flex-start | flex-end | center | baseline;
}
  • stretch (默认值): 如果子元素没有指定高度或设为 auto,将会拉伸占满容器的高度
  • flex-start: 以交叉轴的起点对齐
  • flex-end: 以交叉轴的终点对齐
  • center: 以交叉轴的中点对齐
  • baseline: 以子元素的第一行文字的基线对齐

align-content

定义容器内部多行元素的行对齐方式,类似于 justify-content 定义主轴内元素的对齐方式

**注意: **当只有一行元素时,此属性不生效

.container {
align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}
  • stretch (默认值):每行拉伸占满整个交叉轴
  • flex-start:以交叉轴的起点对齐
  • flex-end:以交叉轴的终点对齐
  • center:以交叉轴的中点对齐
  • space-between:在交叉轴上两端对齐,每行间隔相等
  • space-around:每行两侧的间隔相等,因此,行间隔正好是与边框间隔的两倍

Flex Items

Flex 容器内部的子元素也有 6 个属性,分别是:

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

order

默认情况下,元素按原始顺序排列,但是该属性可以控制元素在 Flex 容器中的显示顺序,数值越小,越靠前,默认为 0。

.item {
order: <integer>; /* default is 0 */
}

flex-grow

定义元素在必要时扩大的能力s,比如容器还有剩余空间。默认为 0,有空间也不扩大。

如果所有元素都设置为 1,那么会均摊容器剩余的空间;如果其中一个元素值为 2,那么它占的剩余空间是其他元素的两倍(至少尽量会这样做)。

**注意: **负值无效。

.item {
flex-grow: <number>; /* default 0 */
}

flex-shrink

定义元素在必要时缩小的能力默认为 1,即如果空间不足,该元素将会缩小。

相对的,如果所有元素此属性值都为 1,空间不足时会等比例缩小;如果有一个元素值为 0,其他为 1,空间不足时,前者不缩小。

**注意: **负值无效。

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

flex-basis

定义在分配容器剩余空间之前,如何判断子元素的大小,浏览器根据此属性计算主轴剩余空间的大小。

值可设为指定长度(如 20%, 5rem)或关键字(auto)。默认为 auto,元素的大小依据 main size(主尺寸),如果 main size 为 auto,则使用元素内容的最大长度。

.item {
flex-basis: <length> | auto; /* default auto */
}

子元素在弹性扩大时, flex-basis 的不同可能会造成不一样的结果,下图分别是"绝对"(从0开始算起)弹性和"相对"(从元素内容长度开始算起)弹性的差异结果。

其中三个子元素 flex-grow 的值为 1:1:2:

  • 如果是 flex-basis:0,浏览器会认为子元素大小为 0,剩余空间就是整个容器空间,那么就会把整个容器空间分配成 1:1:2 的比例
  • 如果是 flex-basis:auto,浏览器会认为子元素大小就是 width 值,计算出剩余空间,按 1:1:2 的比例分配给这个三个元素

由于浏览器计算主轴剩余空间的大小不同,所以导致元素弹性结果的不同。

flex

该属性是 flex-grow, flex-shrinkflex-basis 的简写,其中第二个和第三个参数( flex-shrink 和 flex-basis )是可选的.

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

默认是 flex: 0 1 auto, 建议优先使用此属性,它有两个简便使用的关键字: auto(1 1 auto)none(0 0 auto).

align-self

允许元素覆盖默认的或是使用 align-items 指定的对齐方式。

.item {
align-self: auto | flex-start | flex-end | center | baseline | stretch;
}

除了 auto, 其他属性值都与 align-items 一致。

**注意: **float, clear 和 vertical-align 对 flex 容器内的元素不生效。

浏览器支持

其中:

  • 红色 - 表示版本不支持
  • 黄绿色 - 表示带前缀部分支持
  • 绿色 - 表示版本支持

最后回到题目的问题,常用的垂直居中,只需将 flex 容器的 align-items 和 justify-content 属性值设为 center 即可。

参考: A Complete Guide to Flexbox

还在为垂直居中苦恼?CSS 布局利器 flexbox 轻轻松松帮你搞定的更多相关文章

  1. CSS布局之flexbox

    参考链接: https://www.cnblogs.com/qingchunshiguang/p/8011103.html 练习代码 <!DOCTYPE html> <html la ...

  2. CSS布局(下)

    1.CSS布局之浮动 1.1.float之图文混排 float的意思就是元素漂浮在上层. 可以直接通过设置float属性实现图文混排,代码如下: <div style="width:2 ...

  3. 告别set和get,两大利器轻松搞定model转换

    场景一:一般我们遇到需要新建model,常规做法就是创建一个类,老老实实的定义好model中的所有属性,一般来说属性对应的set方法和get方法都是少不了的,有时候还需要toString甚至equal ...

  4. CSS布局中的水平垂直居中

    CSS布局中的水平垂直居中 各位好,先说两句题外话.今天是我开通博客园的博客第一天,虽然我申请博客园的账号已经有一年半了,但是由于各种原因迟迟没有开通自己的博客.今天非常有幸开通博客,在此也写一篇关于 ...

  5. CSS布局之-水平垂直居中

    对一个元素水平垂直居中,在我们的工作中是会经常遇到的,也是CSS布局中很重要的一部分,本文就来讲讲CSS水平垂直居中的一些方法.另外,文中的css都是用less书写的,如果看不懂less,可以把我给的 ...

  6. css布局 - 垂直居中布局的一百种实现方式(更新中...)

    首先将垂直居中的现象和实现方式两大方向细分类如下: 接下来逐条累加不同情况下的垂直居中实现. 目录: 一.父元素高度固定时,单行文本 | 图片的垂直居中 1. line-height行高简单粗暴实现法 ...

  7. 解读 CSS 布局之水平垂直居中

    对一个元素水平垂直居中,在我们的工作中是会经常遇到的,也是CSS布局中很重要的一部分,本文就来讲讲CSS水平垂直居中的一些方法.由于我们大搜车的日常工作中已经不再需要理会低版本IE,所以本文所贴出的方 ...

  8. CSS布局:元素垂直居中

    CSS布局之元素垂直居中 本文将依次介绍在不同条件下实现垂直居中的多种方法及简单原理 Tip:下文中说的适用场景只是举了几个简单的例子方便读者理解.实际应用场景太复杂,生搬硬套容易出错.最重要的是掌握 ...

  9. CSS布局:元素水平垂直居中

    CSS布局:元素水平垂直居中 本文将依次介绍在不同条件下实现水平垂直居中的多种方法 水平垂直居中是在写网页时经常会用到的需求,在上两篇博客中,分别介绍了水平居中和垂直居中的方法.本文的水平垂直居中就是 ...

随机推荐

  1. HDU 3938:Portal(并查集+离线处理)

    http://acm.hdu.edu.cn/showproblem.php?pid=3938 Portal Problem Description   ZLGG found a magic theor ...

  2. 使用纯js写的一个分页

    上图晒效果: 网上确实有很多分页的插件以及开源代码,单本是一个后台开发猿,前台css等样式还驾驭不住,所以就开始自己去写了.其实这个分页原理很简单,就是用ajax往后台传值(当前页码),后台使用lim ...

  3. C# 实现最小化托盘功能

    winform程序实现最小化托盘显示 1.创建新的解决方案,解决方案名称和路径自定义 2.在解决方案下面新建一个窗体,从左边工具箱,将NotifyIcon拖过去窗体,该控件的作用是:运行程序期间在Wi ...

  4. zookeeper的客户端应用

    什么zookeeper? ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件.它是一个为分布式应用提供 ...

  5. 简单说一下SS的原理

    假设有主机A和B还有C.主机A是客户机,就是你的电脑,主机B是服务器,也就是位于日本的那台电脑.主机C是你需要访问的网站.在没有SS的情况下,数据传输的流程是:A-->C.在有SS的情况下,概括 ...

  6. akka 集群分片

    akka 集群 Sharding分片 分片上下级结构 集群(多台节点机) —> 每台节点机(1个片区) —> 每个片区(多个分片) —> 每个分片(多个实体) 实体: 分片管理的 A ...

  7. 【题解】埃及分数-C++

    Description 在古埃及,人们使用单位分数的和(形如1/a的, a是自然数)表示一切有理数. 如:2/3=1/2+1/6,但不允许2/3=1/3+1/3,因为加数中有相同的. 对于一个分数a/ ...

  8. ASP.NET--Repeater控件分页功能实现

    这两天由于‘销售渠道’系统需要实现新功能,开发了三个页面,三个界面功能大致相同. 功能:分页显示特定sql查询结果,点击上一页下一页均可显示.单击某记录可以选定修改某特定字段<DropDownL ...

  9. python基础一整型、bool、字符串

    1整型.bool.字符串 1.整型 --数字(int) ​ 用于比较运算的 ​ 32位 -2 ** 31 ~ 2 ** 31 -1 ​ 64位 -2 ** 63 ~ 2 ** 63 -1 ​ 基础运算 ...

  10. Excel催化剂开源第51波-Excel催化剂遍历单元格操作性能保障

    在Excel催化剂推出的这一年多时间里,经常性听到一种声音,大概意思是真正会写代码的人,都不会看上Excel催化剂写出来的功能,自己造一个更舒服贴心,仿佛会一点VBA就可以天下无敌一般,也好像Exce ...