CSS3新特性(06):Flex

Flex是Flexible Box的缩写,意为"弹性布局",Flex布局将会是未来布局的首选方案,因为非常便捷,有必要好好学习下。不过目前浏览器支持不是很好,IE11开始才支持。

网上写的各种Flex的文章都说IE10也支持的,我想说,我像你保证IE10不支持的,至少不支持Flex里面的所有属性,所以既然只有IE11开始的浏览器才支持,那么它的使用就可以缓一缓再说,现在只作为概念类项目的学习之用。

下面就来看一下各家浏览器的支持情况,“+”表示包括且大于的意思,先上图。

Flex里的新鲜概念剖析

Flex是个蛮复杂的布局,在学习之前,先来了解下有关Flex里的新鲜概念。假设我们看到下图的紫色html元素它是弹性布局的,我们就称其为Flex container,意思是弹性的容器。

它有两个直接的子元素,我们称之为Flex item,意思是弹性的元素。

我们把Flex item排列的方向称为main axis,意思是主轴。

而跟主轴垂直的方向,我们把它称为cross axis,意思是辅轴。

这些概念我们在下面会经常使用到,所以先要记住。

那么我们如何设置弹性布局呢,只要display:flex就搞定了,那么Flex item又是什么呢,即设置过display:flex的html元素它在文档流中的子元素就是Flex item了。

判断哪些是有效的Flex item

并不是设置过display:flex的html元素它里面的任何元素都是Flex item。而是它的在文档流中的子元素才是Flex item。两个条件,一是在文档流中,二是子元素。下面我们就来判断下哪些是有效的Flex item?

float元素是在文档流中的子元素,因此算Flex item,absolute绝对定位的元素是脱离文档流的,不能算,至于最后一个是孙元素,也不能算。

弹性布局的特性

接下来我们来讲讲弹性布局的特性,从三个方面来讲,分别是排列方向、弹性、对齐。

排列方向

排列方向有关的属性有这些:flex-direction(弹性的方向)、flex-wrap(弹性的换行)、flex-flow(flex-direction 和 flex-wrap 属性的复合属性)、order(顺序)。下面分别来介绍下。

(1)首先我们来看一下flex-direction(弹性的方向),它的语法如下:

flex-direction:row|row-reverse|column|column-reverse;

flex-direction是设置弹性布局的方向,默认是row。

285.jpg

(2)接下来我们来看一下flex-wrap(弹性的换行),它的语法如下:

flex-wrap:nowrap|wrap|wrap-reverse;

flex-wrap是设置弹性布局的换行,默认是nowrap,即不换行。

(3)接下来我们来看一下flex-flow,它是flex-direction 和 flex-wrap 属性的复合属性,它的语法如下:

flex-flow:flex-direction||flex-wrap;

默认是row nowrap,即横方向排列且不换行。

287.jpg

使用时建议使用复合属性flex-flow,非单独属性flex-direction 和 flex-wrap。

(4)再来看一下order(顺序),默认值为0。它的语法如下:

order:number;

order:1的元素大于order:0的另两个元素,于是顺序就调换了。order的值为整数,可负数。

弹性

弹性有关的属性有这些:flex-basis(设置flex-item的初始宽高)、flex-grow、flex-shrink。下面分别来介绍下。

(1)首先我们来看一下flex-basis(设置flex-item的初始宽高),它也会作为以后设置弹性的基础,它的语法:

flex-basis: number|auto|initial(默认)|inherit;

这里要提一下,如果设置默认值的话,若该弹性元素是横向排列的,即为主轴main axis的宽度,若是纵向排列的,即为辅轴cross axis,也就是高度了。

(2)接下来我们来看一下flex-grow,该属性用于设置弹性盒的能分配到的剩余空间的扩展比率。如果元素不是弹性盒对象的元素,则 flex-grow 属性不起作用。默认值是0,它的语法:

flex-grow: number;

(3)接下来我们来看一下flex-shrink,它是设置弹性元素的能分配到的剩余空间的收缩比例,默认值是1,它的语法:

flex-shrink: number;

(4)接下来我们来讲讲flex这个复合属性,它的语法:

flex: flex-grow||flex-shrink||flex-basis;

使用时建议使用复合属性flex。

对齐

对齐有关的属性有这些:justify-content(设置主轴方向的对齐方式)、align-items(设置辅轴方向的对齐方式)、align-self、align-content。下面分别来介绍下。

(1)首先我们来看一下justify-content(设置主轴main-axis方向的对齐方式),它的语法:

justify-content: flex-start|flex-end|center|space-between|space-around;

(2)接下来我们来看一下align-items(设置辅轴cross-axis方向的对齐方式),它的语法:

align-items: flex-start|flex-end|center|baseline|stretch;

看的清楚么?看不清楚我们再换一张效果图:

(3)接下来我们来看一下align-self(设置单个flex item在cross-axis方向上的对齐方式),它的语法:

align-self: auto|flex-start|flex-end|center|baseline|stretch;

这个跟align-items差不多,所以效果图就不放了。

(4)接下来我们来看一下align-content(设置cross-axis方向上行的对齐方式),它的语法:


align-content: auto|flex-start|flex-end|center|space-between|space-around|stretch;

align-content是当出现多行时,多行如何对齐,可以看到上图有三行,图中显示就是三行的分别对齐方式。

总之:flex弹性布局的基础知识讲完了,以后有空会补充实例篇。

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

推荐阅读更多精彩内容

  • 移动开发基本知识点 一.使用rem作为单位 html { font-size: 100px; } @media(m...
    横冲直撞666阅读 3,447评论 0 6
  • H5移动端知识点总结 阅读目录 移动开发基本知识点 calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇阅读 4,368评论 0 26
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,715评论 1 92
  • 在以前页面布局多依赖于table,但table标签太多,于是有了absolute布局,float布局等,但它们小问...
    张歆琳阅读 4,041评论 3 55
  • 阅读目录移动开发基本知识点 calc基本用法box-sizing的理解及使用理解display:box的布局理解f...
    张宪宇阅读 1,500评论 0 1