Flexbox属性可视化指南
Flexbox 布局(国内很多人称为弹性布局)正式的全称为 CSS Flexible Box布局模块,它是CSS3新增的一种布局模式。它可以很方便地用来改善动态或未知大小的元素的对齐,方向和顺序等等。flex容器的主要特性是它可以调整其子元素的宽度或高度去填充可用的空白区,以最优的方式达到兼容不同屏幕大小。
很多设计人员和开发人员发现使用Flexbox来布局很容易,可以使用更少的代码,更简单的方式实现更复杂的布局,也使整个开发过程更为简单。Flexbox布局算法不同于那些基于垂直或水平的块或内联布局。Flexbox布局应该用于小的应用程序组件之中,而新的CSS 网格布局模块正在兴起,来处理大规模布局。
本指南将以可视化的方式重点介绍 flex 属性是如何影响布局的,不是解释 flex 属性是如何工作。
基础
在我们开始介绍 flexbox属性之前,让我们先稍微介绍一下 flexbox模型。flex布局由被称为 flex container(flex容器) 的父容器 和被称为 flex item(flex项)的直接子元素构成。
在上面的图片中,您可以看到用于描述 flex container(flex容器) 及其子元素的属性和术语。关于他们意义的更多信息,请阅读 W3C flexbox模型 的官方文档。
愚人码头注:
要是看英文比较吃力,你可以查看 《Flexbox布局(CSS3 弹性布局,Flexible Box)之 基本概念解析》 这篇文章。
从2009年的最初草案开始,flexbox布局经历了多次迭代和几个版本的语法变更,所以为了避免混乱,我们将只使用最新的工作草案(2014年9月)中的语法。如果你需要维护旧的浏览器兼容性,你可以阅读这篇文章,了解如何以最好的方式做到这一点。
愚人码头注:
目前解决flexbox版本兼容性问题,一般可以使用Autoprefixer后处理程序来实现css3代码自动补全;
如果你使用 Sass,也可以使用@mixin
(混入)来解决 flexbox版本兼容,推荐一个github项目:sass-flex-mixin。
浏览器对最新flexbox规范的支持情况:
- Chrome 29+
- Firefox 28+
- Internet Explorer 11+
- Opera 17+
- Safari 6.1+ (加前缀
-webkit-
) - Android 4.4+
- iOS 7.1+ (加前缀
-webkit-
)
如果你需要查看更多浏览器兼容性,你可以看这里。
使用
使用flexbox布局只要在父级HTML元素上设置display
属性:
- .flex-container {
- display: -webkit-flex; /* Safari */
- display: flex;
- }
或者如果你想将它像一个内联元素显示使用:
- .flex-container {
- display: -webkit-inline-flex; /* Safari */
- display: inline-flex;
- }
注意:这是需要你在父容器上设置的唯一属性,并且其所有直接子元素将自动成为 flex item(flex项)。
有几种方法可以将 flexbox 属性进行分组,迄今为止,我发现的了解 flexbox 选项的最简单的方法是将 flexbox 属性分成 flex container(flex容器)和 flex item(flex项) 两组。下面,我们将按照这两个分组解释每个flexbox 属性是如何在视觉上影响布局的。
Flexbox container 属性
flex-direction
这个属性通过设置 flex container(flex容器) 的主轴方向,来指定 flex item(flex项) 在 flex container(flex容器) 中是如何布局的。flex item(flex项) 可以在两个主轴方向上排列布局,水平横向和垂直纵向两种。
属性值:
- .flex-container {
- -webkit-flex-direction: row; /* Safari */
- flex-direction: row;
- }
值为 row
方向,那么在ltr
上下文中,所有 flex item(flex项) 从左到右排成一行。如图:
- .flex-container {
- -webkit-flex-direction: row-reverse; /* Safari */
- flex-direction: row-reverse;
- }
值为 row-reverse
方向,那么在ltr
上下文中,所有 flex item(flex项) 从右到左排成一行。( 愚人码头注:reverse 为相反方向,很好记忆吧)如图:
- .flex-container {
- -webkit-flex-direction: column; /* Safari */
- flex-direction: column;
- }
值为 column
方向,那么所有 flex item(flex项) 从上到下排成一列。如图:
- .flex-container {
- -webkit-flex-direction: column-reverse; /* Safari */
- flex-direction: column-reverse;
- }
值为 column-reverse
方向,那么所有 flex item(flex项) 从下到上排成一列。如图:
默认值: row
注意:row
和row-reverse
的排列方式取决于书写模式,所以如果是在rtl
上下文中,它们会反向排序。
flex-wrap
默认情况下,flexbox 理念是将容器中的所有子元素设置在一行中。flex-wrap
属性可以控制 flex container(flex容器) 以单行还是多行布局其flex item(flex项),以及在新行上的排列方向。
属性值:
- .flex-container {
- -webkit-flex-wrap: nowrap; /* Safari */
- flex-wrap: nowrap;
- }
flex item(flex项) 会显示成一行,默认情况下,它们会自动伸缩,以适应 flex container(flex容器)的宽度。如图:
- .flex-container {
- -webkit-flex-wrap: wrap; /* Safari */
- flex-wrap: wrap;
- }
flex item(flex项)会在flex container(flex容器)中, 按照从左到右,从上到下的顺序显示成多行。如图:
- .flex-container {
- -webkit-flex-wrap: wrap-reverse; /* Safari */
- flex-wrap: wrap-reverse;
- }
flex item(flex项)会在flex container(flex容器)中, 按照从左到右,从下到上的顺序显示成多行。如图:
默认值: nowrap
注意:这些属性取决于书写模式,所以如果是在rtl
上下文中,它们会反向排序。
flex-flow
这个属性是设置flex-direction
和flex-wrap
属性的速记写法(简写或缩写)。
属性值:
- .flex-container {
- -webkit-flex-flow: || ; /* Safari */
- flex-flow: || ;
- }
默认值: row nowrap
justify-content
justify-content
属性用来指定 flex item(flex项)在当前 flex container(flex容器)主轴线(main axis)上的对齐方式。当所有flex item(flex项)都在同一行并且不可伸缩,或是可伸缩但已经达到它们最大尺寸的时候,它可以分配主轴线(main axis)上的剩余空间。
属性值:
- .flex-container {
- -webkit-justify-content: flex-start; /* Safari */
- justify-content: flex-start;
- }
在ltr上下文中, flex item(flex项)会在 flex container(flex容器)中靠左对齐。如图:
- .flex-container {
- -webkit-justify-content: flex-end; /* Safari */
- justify-content: flex-end;
- }
在ltr上下文中, flex item(flex项)会在 flex container(flex容器)中靠右对齐。如图:
- .flex-container {
- -webkit-justify-content: center; /* Safari */
- justify-content: center;
- }
flex item(flex项)会在 flex container(flex容器)中靠中间对齐(居中对齐)。如图:
- .flex-container {
- -webkit-justify-content: space-between; /* Safari */
- justify-content: space-between;
- }
flex item(flex项)之间以相等的间距显示,第一个和最后一个flex item(flex项)会在 flex container(flex容器)中靠两侧边缘对齐(愚人码头注:类似于常说的两端对齐)。如图:
- .flex-container {
- -webkit-justify-content: space-around; /* Safari */
- justify-content: space-around;
- }
flex item(flex项)以相同的空间间隔显示,甚至第一个和最后一个flex item(flex项)。如图:
默认值: flex-start
愚人码头注:
特别说明的是:上面都是flex container(flex容器)主轴线 横向的例子,即flex-direction:row;
。纵向的例子可以使用flex-direction:column;
试试…。
align-items
flex item(flex项)可以在 flex container(flex容器)的当前交叉轴(cross axis)上对齐方式,类似于justify-content
,但是在垂直方向。
此属性设置所有flex item(flex项)的默认对齐方式,并且包括匿名元素。
愚人码头注:
justify-content
是设置flex item(flex项)在主轴线(main axis)上的对齐方式;align-items
是设置flex item(flex项)在交叉轴(cross axis)上对齐方式;
属性值:
- .flex-container {
- -webkit-align-items: stretch; /* Safari */
- align-items: stretch;
- }
flex item(flex项)会从cross start到cross end结束,填满整个 flex container(flex容器)的高度(或宽度)。如图:
愚人码头注:
这里解释一下填满整个 flex container(flex容器)的宽度的情况:
当flex-direction:column;
或者flex-direction:column-reverse;
时,将flex item(flex项)的宽度设置auto
或者100%
就可以了。
- .flex-container {
- -webkit-align-items: flex-start; /* Safari */
- align-items: flex-start;
- }
flex item(flex项)会以flex container(flex容器) 的交叉轴起始(cross start)线对齐。如图:
- .flex-container {
- -webkit-align-items: flex-end; /* Safari */
- align-items: flex-end;
- }
flex item(flex项)会以flex container(flex容器) 的交叉轴结尾(cross end)线对齐。如图:
- .flex-container {
- -webkit-align-items: center; /* Safari */
- align-items: center;
- }
flex item(flex项)会以flex container(flex容器) 的交叉轴(cross axis)的中间对齐。如图:
- .flex-container {
- -webkit-align-items: baseline; /* Safari */
- align-items: baseline;
- }
flex item(flex项)会按照她们的文本基线(baseline)对象。
愚人码头注:
科普:文本基线(英语:Baseline)指的是多数字母排列的基准线。详细说明请查看维基百科中关于Baseline的说明
默认值: stretch
注意:有关于文本基线计算的更多说明可以查看这里。
align-content
当flex container(flex容器)的交叉轴(cross axis)上存在多余空间(愚人码头注:未被填充满)时,align-content
属性可以控制 flex item(flex项)在 flex container(flex容器)的交叉轴(cross axis)上的对齐方式。类似于justify-content
在主轴(main axis)方向上各个 flex item(flex项)的对齐。
属性值:
- .flex-container {
- -webkit-align-content: stretch; /* Safari */
- align-content: stretch;
- }
flex item(flex项)在每行flex item(flex项)的后面都显示分布式空间。如图:
- .flex-container {
- -webkit-align-content: flex-start; /* Safari */
- align-content: flex-start;
- }
flex item(flex项)会堆砌在flex container(flex容器)的交叉轴(cross axis)的起始位置上。如图:
- .flex-container {
- -webkit-align-content: flex-end; /* Safari */
- align-content: flex-end;
- }
flex item(flex项)会堆砌在 flex container(flex容器)的交叉轴(cross axis)的结束位置上。如图:
- .flex-container {
- -webkit-align-content: center; /* Safari */
- align-content: center;
- }
flex item(flex项)会堆砌在flex container(flex容器)的交叉轴(cross axis)的居中位置上。如图:
- .flex-container {
- -webkit-align-content: space-between; /* Safari */
- align-content: space-between;
- }
flex item(flex项)的行与行之间以相等的间隔显示,第一行和最后一行分别显示在flex container(flex容器)的交叉轴(cross axis)的两端。如图:
- .flex-container {
- -webkit-align-content: space-around; /* Safari */
- align-content: space-around;
- }
flex item(flex项)的每一行以相等的间隔显示。如图:
默认值: stretch
注意:这个属性只有当 flex container(flex容器)有多行 flex item(flex项)时才生效,如果只有一行,那么这个属性没有效果。
flex container(flex容器)的注意点
- 所有的
column-*
属性在flex container(flex容器)上都不会有效果 ::first-line
与::first-letter
伪类在flex container(flex容器)上不会被应用。
flex item(flex项)的属性
order
order
属性用来控制 flex container(flex容器)中 flex item(flex项)的排列顺序。默认情况下,以它们被添加到 flex container(flex容器)中的顺序排序(愚人码头注:可以理解为以HTML结构的顺序排序)。
属性值:
- .flex-item {
- -webkit-order: ; /* Safari */
- order: ;
- }
flex item(flex项)可以使用这个简单的属性重新排序,而不需要重新修改HTML代码。
默认值: 0
flex-grow
当 flex container(flex容器)存在剩余空间时,可以用flex-grow
这个属性来确定 flex item(flex项)的拉伸比例。
属性值:
- .flex-item {
- -webkit-flex-grow: ; /* Safari */
- flex-grow: ;
- }
如果所有 flex item(flex项)具有相同的flex-grow
值,那么所有 flex item(flex项)在 flex container(flex容器)中具有相同的大小。
第二个 flex item(flex项) 相对于其他 flex item(flex项) 占用更多空间。
默认值: 0
注意:负数值无效。
flex-shrink
当 flex container(flex容器)空间不足时,可以用flex-shrink
这个属性来确定 flex item(flex项)的收缩比例。
属性值:
- .flex-item {
- -webkit-flex-shrink: ; /* Safari */
- flex-shrink: ;
- }
默认情况下,所有 flex item(flex项)都可以收缩,但如果我们将它设置为 0(不收缩),它们将保持原来的大小。
默认值: 1
注意:负数值无效。
flex-basis
这个属性看作width
和height
属性相同的值,并在 flex 伸缩比例分配剩余空间之前,指定 flex item(flex项)的初始主要大小(愚人码头注: flex-grow
和 flex-shrink
伸缩比例分配剩余空间之前)。
属性值:
- .flex-item {
- -webkit-flex-basis: auto | <width>; /* Safari */
- flex-basis: auto | <width>;
- }
指定了第4个 flex item(flex项)元素的初始大小。如图:
flex-basis
默认值: 1
注意: auto
值存在一个问题,将在未来解决。
flex
这个属性是flex-grow
,flex-shrink
和flex-basis
属性的速记写法(简写或缩写)。 除了其他值,它也可以设置为auto
(即:1 1 auto
)和none
(即:0 0 auto
)。
- .flex-item {
- -webkit-flex: none | auto | [ ? || ]; /* Safari */
- flex: none | auto | [ ? || ];
- }
默认值: 0 1 auto
注意:W3C鼓励使用 flex 简写,而不是每个属性都分开写,因为速记正确地重置了未指定的属性,以适应常见用途。
align-self
这个align-self
属性允许覆盖单个的 flex item(flex项)默认对齐方式(或由align-items
指定的值)。请参阅flex container(flex容器)的align-items
说明以了解可用的值。
属性值:
- .flex-item {
- -webkit-align-self: auto | flex-start | flex-end | center | baseline | stretch; /* Safari */
- align-self: auto | flex-start | flex-end | center | baseline | stretch;
- }
第3和第4个 flex item(flex项)通过align-self
属性覆盖了其默认的对齐方式。如图:
默认值: auto
注意:align-self
取值为auto
值时,其值被计算为父级元素的align-items
属性的值,或者如果元素没有父元素,那么其值为stretch
。
flex item(flex项)的注意点
float
,clear
和vertical-align
在flex item(flex项)上都不会起作用,也不会让它脱离文档流。
Flexbox属性可视化指南的更多相关文章
- 转载:CSS3 Flexbox可视化指南
0. 目录 目录 引言 正文 1 引入 2 基础 3 使用 4 弹性容器Flex container属性 41 flex-direction 42 flex-wrap 43 flex-flow 44 ...
- CSS3 Flexbox可视化指南
0. 目录 目录 引言 正文 1 引入 2 基础 3 使用 4 弹性容器Flex container属性 41 flex-direction 42 flex-wrap 43 flex-flow 44 ...
- Flex布局 Flexbox属性具体解释
原文:A Visual Guide to CSS3 Flexbox Properties Flex布局官方称为CSS Flexble Box布局模型是CSS3为了提高元素在容器中的对齐.方向.顺序,甚 ...
- Go内存分配器可视化指南【译】【精】
当我第一次开始尝试理解 Go 语言的内存分配器时,整个过程让我抓狂.一切看起来都像一个神秘的黑盒子.因为几乎所有技术魔法(technical wizardry)都隐藏在抽象之下,所以你需要一层一层的剥 ...
- CSS3 Flexbox(伸缩盒/弹性盒模型)可视化指南
在http://css.doyoe.com/(CSS参考手册)中,本文对应其中的伸缩盒 引入 Flexbox布局官方称为CSS Flexible Box Layout Module是一个CSS3新的布 ...
- CSS3 Flexbox不迷路指南
Flexbox早有耳闻,但是决定切实尝试一番,还是因为看了这条围脖: 我觉得用flexbox可以实现,但是发觉无从下手,属性特性都不了解.趁此机会,学习下. 英文原版参考资料在这里:A Complet ...
- Flexbox属性查询列表
1.任何一个flexbox布局的第一步是需要创建一个flex容器.为此给元素设置display属性的值为flex.在Safari浏览器中,你依然需要添加前缀-webkit. .flexcontaine ...
- flexbox属性速览及常见布局实现
CSS3 弹性盒子(Flex Box)弹性盒子是即 CSS2 浮动布局后, CSS3 的一种新的布局模式. CSS3 弹性盒( Flexible Box 或 flexbox),是一种当页面需要适应不同 ...
- 我的Vue之旅、01 深入Flexbox布局完全指南
花了几个小时整合的"A Complete Guide to Flexbox"最新版本,介绍了flexbox的所有属性,外带几个实用的例子. 传统布局.Flexbox 布局的传统解决 ...
随机推荐
- mount USB Device(U disk) on crux based on vmware
1. 在 /mnt 下建立一个名叫USB的文件夹,文件夹名自定 cd /mnt mkdir USB 2. 查看一下磁盘分区情况 fdisk –l 3. 插入U盘 4. 再次查看磁盘分区情况,对比第一次 ...
- 如何把java代码转换成smali代码
1.概述 Smali是Android系统中Dalvik虚拟机指令语言,在apk逆向过程中有许多工具可以把smali代码转化成java代码.但是在学习Smali语法的过程中,有时候需要进行java代码和 ...
- SQL获取前一天0:00:00至23:59:59数据
一.前言 因为我公司要做财务结算前一天0:00:00至23:59:59的数据,利用到动态拼接SQL语句 我们需要明白声明DateTime 和 Date 获取的时间格式是不一样的,所以通过此计算有利于得 ...
- Stata和Matlab联合处理金融数据
Stata是统计学专业软件,可以很方便的对数据处理,但几乎只能按照整行整列进行,而且每次只能加载一个矩阵(dta文件),如果要用到多个矩阵数据进行操作或进行复杂的循环控制,就力不从心了. 而Matla ...
- HDU 4612 (13年多校第二场1002)无向图缩点,有重边
这道题是多校的题,比赛的时候是一道纷纷水过的板刷题. 题意:给你一些无向边,只加一条边,使该图的桥最少,然后输出最少的桥. 思路:当时大致想到思路了,就是缩点之后找出最长的链,然后用总的桥数减去链上的 ...
- JSON基础知识
1.什么是json • JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation) • JSON 是轻量级的文本数据交换格式 ...
- chart.js 示例
一个简单的例子. 1.html代码 <div id="pie" style="width: 250px;float:left"> <h3> ...
- React java.lang.UnsatisfiedLinkError: dlopen failed: "/data/data/com.edaixi.activity/lib-main/libgnustl_shared.so" is 32-bit instead of 64-bit
E/AndroidRuntime: FATAL EXCEPTION: main Process: com.edaixi.activity, PID: 3659 at java.lang.Runtime ...
- JSP EL
一.JSP EL语言定义 E L(Expression Language) 目的:为了使JSP写起来更加简单. 表达式语言的灵感来自于 ECMAScript 和 XPath 表达式语言,它提供了在 ...
- lnmp 60秒的服务器缓存时间
1.问题 php代码写好之后执行发现居然没有生效,打断点,改代码.刷新都没有达到预期的效果.但是间隔60秒之后刷新就看到效果了,或者删除文件就里面见效. 2.原因 从phpinfo()页面输出搜索&q ...