最直观的方式学习flexbox属性

英文原文:A Visual Guide to CSS3 Flexbox Properties
译文地址:http://w3ctrain.com/2015/11/12/visual-guide-to-css3-flexbox-flexbox-playground/

弹性盒模型(Flexbox Layout)是CSS3新增的一种布局模式。它可以很方便地用来改善动态或未知大小的子元素在父元素中的对齐,方向和顺序等等。flex容器的主要特性是它可以调整子元素的宽度或高度去填充可用的空白区,以最优的方式达到兼容不同屏幕大小。

很多设计师和开发人员发现flexbox布局很容易使用,因为元素的定位非常简单,只需要写很少的代码,就能达到预期效果。Flexbox布局算法不同于那些基于垂直或水平的块或内联布局。Flexbox布局应该用在小项目中的组件。

这篇文章主要集中在说明flex属性如何影响布局,而不是这些属性如何工作。

可能你会觉得flex很多属性很难记住,或是看了很多文字说明但是不知道具体效果如何,那么这篇文章就非常适合你了。

让我们开始吧!

BASICS

在我们开始之前先来定下规则,我们把父容器称为flex container,它的直接子元素称为flex items

上面的盒子中,你可以看到用来描述flex container 和 它的子元素的属性与术语。如果你需要查看更多,点击这里

flexbox从2009年的初稿走到现在,经历了时间的洗练和各种语法的变更。所以为了避免冲突,这篇文章我们只使用最新并且有效的版本。如果你需要兼容旧浏览器,你可以看看这篇文章。(英文)

最新的flexbox兼容以下浏览器:

  • Chrome 29+
  • Firefox 28+
  • Internet Explorer 11+
  • Opera 17+
  • Safari 6.1+ (prefixed with -webkit-)
  • Android 4.4+
  • iOS 7.1+ (prefixed with -webkit-)

如果你需要查看更多浏览器兼容性,你可以看这里

USAGE

使用flexbox布局,你需要在父元素上设置display属性

.flex-container {
  display: -webkit-flex; /* Safari */
  display: flex;
}

或者你可以把它当行内元素使用

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

注意:你给父容器设置了这个属性后,它的子元素都会自动变成flex items。

有很多种给flexbox属性分组的方式,到目前为止,我认为最简单,并且最容易理解的方式是按照flex container和flex items分成两组。下面,我们来解释各个元素是如何影响布局效果的。

Flexbox Container 属性

flex-direction
这个属性指定了flex items在flex container中是如何布局的。通过设置flex container的主轴的方向,它们会按照两个方向布局,水平的行或者垂直的列。

例子:

.flex-container {
  -webkit-flex-direction: row; /* Safari */
  flex-direction:         row;
}

设置为行,那么在ltr上下文环境下,所有flex items会按照从左到右的顺序排成一行。

.flex-container {
  -webkit-flex-direction: row-reverse; /* Safari */
  flex-direction:         row-reverse;
}

使用row-reverse属性,那么在ltr上下文环境下,子元素则会按照从右到左的顺序排成一行。

.flex-container {
  -webkit-flex-direction: column; /* Safari */
  flex-direction:         column;
}

使用column属性,flex items会按照从上到下的方式排列。

.flex-container {
  -webkit-flex-direction: column-reverse; /* Safari */
  flex-direction:         column-reverse;
}

使用column-reverse,则会放过来。

默认值:row

注:row和row-reverse的排列方式取决于书写模式,所以如果是在rtl上下文环境下,它们都会反转。

flex-wrap

默认的flexbox概念是把所有子元素都放在一行里面,你可以通过flex-wrap属性来控制flex container是否将子元素分多行处理,以及新增行的方向。

例子:

.flex-container {
  -webkit-flex-wrap: nowrap; /* Safari */
  flex-wrap:         nowrap;
}

Flex items会被置在一行里面,并且默认它们会被压缩来适应容器的宽度。

.flex-container {
  -webkit-flex-wrap: wrap; /* Safari */
  flex-wrap:         wrap;
}

wrap, Flex items会被按照从上到下从左到右的顺序分配到多行。

.flex-container {
  -webkit-flex-wrap: wrap-reverse; /* Safari */
  flex-wrap:         wrap-reverse;
}

wrap-reverse, Flex itms会被按照从左到右从下到上的顺序在多行中显示。

默认值:nowrap

注:这个属性也跟书写模式相关。

flex-flow

这个属性是flex-direction和flex-wrap属性的缩写。

例子:

.flex-container {
  -webkit-flex-flow: <flex-direction> || <flex-wrap>; /* Safari */
  flex-flow:         <flex-direction> || <flex-wrap>;
}

默认值:row nowrap

justify-content

这个属性会根据当前容器的主轴来排列子元素。它可以在所有flex items都在同一行并且不可伸缩,或是可伸缩但是达到它们的最大尺寸时候,分配剩余空间。

例子:

.flex-container {
  -webkit-justify-content: flex-start; /* Safari */
  justify-content:         flex-start;
}

Flex items在lrt上下文中会向左边靠拢

.flex-container {
  -webkit-justify-content: flex-end; /* Safari */
  justify-content:         flex-end;
}

Flex items在ltr上下文中向右靠拢

.flex-container {
  -webkit-justify-content: center; /* Safari */
  justify-content:         center;
}

Flex items会居中

.flex-container {
  -webkit-justify-content: space-between; /* Safari */
  justify-content:         space-between;
}

除了第一个和最后一个,Flex items会有相同的间隔。

.flex-container {
  -webkit-justify-content: space-around; /* Safari */
  justify-content:         space-around;
}

所有Flex item 都会有相同间隔

默认值: flex-start

align-items

Flex items 会根据当前容器的主轴线对齐,跟justify-content很相似,但是方向垂直。这个属性设置所有flex items默认对齐方式。例子:

.flex-container {
  -webkit-align-items: stretch; /* Safari */
  align-items:         stretch;
}

Flex items会占满flex container的高度,从cross start到cross end

.flex-container {
  -webkit-align-items: flex-start; /* Safari */
  align-items:         flex-start;
}

Flex items会与flex container 的交叉轴起始(cross start)线对齐。

.flex-container {
  -webkit-align-items: flex-end; /* Safari */
  align-items:         flex-end;
}

Flex items会与flex container 的交叉轴结尾(cross end)线对齐。

.flex-container {
  -webkit-align-items: center; /* Safari */
  align-items:         center;
}

Flex items会在交叉轴(cross axis)上对齐

.flex-container {
  -webkit-align-items: baseline; /* Safari */
  align-items:         baseline;
}

Flex items会按照它们的基线(baselines)对齐

默认值:stretch
注:点击这里查看更多关于基线如何运算

align-content

align-content属性对齐flex container上的行,控制交叉轴的多余间隔,跟主轴上的justify-content属性很相似。

例子:

.flex-container {
  -webkit-align-content: stretch; /* Safari */
  align-content:         stretch;
}

每一行Flex items后面都会有区分开的间隔。

.flex-container {
  -webkit-align-content: flex-start; /* Safari */
  align-content:         flex-start;
}

Flex items会向交叉轴起始位置靠拢

.flex-container {
  -webkit-align-content: flex-end; /* Safari */
  align-content:         flex-end;
}

Flex items 会向交叉轴的结束位置靠拢

.flex-container {
  -webkit-align-content: center; /* Safari */
  align-content:         center;
}

flex items的行会在交叉轴上居中显示

.flex-container {
  -webkit-align-content: space-between; /* Safari */
  align-content:         space-between;
}

除了起始和结尾行,flex items的其他行都会有相同的间隔。

.flex-container {
  -webkit-align-content: space-around; /* Safari */
  align-content:         space-around;
}

每一行都会有相同上下间隔

默认值:stretch
注:这个属性只会在flex container有多行的时候才会有效,如果只有一行那么这个属性就不会有效果。

关于flex containers

  • 所有的column-*属性在flex container上都不会有效果
  • ::first-line::first-letter伪类在flex container上不会被应用。

FlexBox Item 属性

Order
order属性定义子元素在父容器中的顺序,默认它们会被最加到后面

例子:

.flex-item {
  -webkit-order: <integer>; /* Safari */
  order:         <integer>;
}

不需要调整HTML,就能修改显示顺序

默认值:0

flex-grow

这个属性是一个flex拉伸因子,决定了flex items会相对于父容器剩余空间增长多少。

.flex-item {
  -webkit-flex-grow: <number>; /* Safari */
  flex-grow:         <number>;
}

如果所有flex items都有相同的flex-grow,那么他们都会在父容器中有相同的尺寸。

调整一下,看看有什么区别

默认值:0
注:负数是不合法的

flex-shrink

flex-shrink是一个flex收缩因子,它决定了当父容器体积不足时,flex items收缩的相对比例。

.flex-item {
  -webkit-flex-shrink: <number>; /* Safari */
  flex-shrink:         <number>;
}

默认所有flex items都是可以压缩的,但如果我们把它设为0,那么它将保持原有大小。

默认值: 1**
注:**负数是不合法的

flex-basis

这个属性会设置宽度和高度,原文为:This property takes the same values as the width and height properties并在flex因子分割间隔之前,指定flex items的初始大小。

.flex-item {
  -webkit-flex-basis: auto | <width>; /* Safari */
  flex-basis:         auto | <width>;
}

flex-basis会指定第四个flex items的初始大小

默认值: auto

flex

这个属性是flex-grow,flex-shrinkflex-basis属性的缩写。

.flex-item {
  -webkit-flex: none | auto | [ <flex-grow> <flex-shrink>? || <flex-basis> ]; /* Safari */
  flex:         none | auto | [ <flex-grow> <flex-shrink>? || <flex-basis> ];
}

默认值:0 1 auto
注:w3c鼓励使用简写,而不是每个属性都分开写。

align-self

这个属性允许为单个flex 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;
}


默认值:auto**
注:**The value of auto for align-self computes to the value of align-items on the element’s parent, or stretch if the element has no parent.

关于flex items

  • float, clear,vertical-align在flex item上都不会有作用,也不会让它脱离文档流。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容

  • H5移动端知识点总结 阅读目录 移动开发基本知识点 calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇阅读 4,464评论 0 26
  • 移动开发基本知识点 一.使用rem作为单位 html { font-size: 100px; } @media(m...
    横冲直撞666阅读 3,462评论 0 6
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,744评论 1 92
  • Flexbox布局官方称之为CSS Flexible Box布局模块,他是CSS3中的一种新的布局模式。Flexb...
    流动码文阅读 700评论 0 3
  • 简书的Markdown貌似不支持插入iframe,所以文章里的JSFiddle示例都改做截图了,如果有需要可以点击...
    kangflict阅读 1,113评论 2 8