网页布局(layout)是 CSS 的一个重点应用。

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

2009年,W3C 提出了一种新的方案----Flex 布局,可以简便、完整、响应式地实现各种页面布局。目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能。

Flex 布局将成为未来布局的首选方案。本文介绍它的语法,下一篇文章给出常见布局的 Flex 写法。网友 JailBreak 为本文的所有示例制作了 Demo,也可以参考。

以下内容主要参考了下面两篇文章:A Complete Guide to Flexbox 和 A Visual Guide to CSS3 Flexbox Properties。

一、Flex 布局是什么?

Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。

任何一个容器都可以指定为 Flex 布局。


.box{display: flex; } 

行内元素也可以使用 Flex 布局。


.box{display: inline-flex; } 

Webkit 内核的浏览器,必须加上-webkit前缀。


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

注意,设为 Flex 布局以后,子元素的floatclearvertical-align属性将失效。

二、基本概念

采用 Flex 布局的元素,称为 Flex 容器(flex container),简称"容器"。它的所有子元素自动成为容器成员,称为 Flex 项目(flex item),简称"项目"。

容器默认存在两根轴:水平的主轴(main axis)和垂直的交叉轴(cross axis)。主轴的开始位置(与边框的交叉点)叫做main start,结束位置叫做main end;交叉轴的开始位置叫做cross start,结束位置叫做cross end

项目默认沿主轴排列。单个项目占据的主轴空间叫做main size,占据的交叉轴空间叫做cross size

三、容器的属性

以下6个属性设置在容器上。

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

3.1 flex-direction属性

flex-direction属性决定主轴的方向(即项目的排列方向)。


.box {flex-direction: row | row-reverse | column | column-reverse; } 

它可能有4个值。

  • row(默认值):主轴为水平方向,起点在左端。
  • row-reverse:主轴为水平方向,起点在右端。
  • column:主轴为垂直方向,起点在上沿。
  • column-reverse:主轴为垂直方向,起点在下沿。

3.2 flex-wrap属性

默认情况下,项目都排在一条线(又称"轴线")上。flex-wrap属性定义,如果一条轴线排不下,如何换行。


.box{flex-wrap: nowrap | wrap | wrap-reverse; } 

它可能取三个值。

(1)nowrap(默认):不换行。

(2)wrap:换行,第一行在上方。

(3)wrap-reverse:换行,第一行在下方。

3.3 flex-flow

flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap


.box {flex-flow: <flex-direction> || <flex-wrap>; } 

3.4 justify-content属性

justify-content属性定义了项目在主轴上的对齐方式。


.box {justify-content: flex-start | flex-end | center | space-between | space-around; } 

它可能取5个值,具体对齐方式与轴的方向有关。下面假设主轴为从左到右。

  • flex-start(默认值):左对齐
  • flex-end:右对齐
  • center: 居中
  • space-between:两端对齐,项目之间的间隔都相等。
  • space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。

3.5 align-items属性

align-items属性定义项目在交叉轴上如何对齐。


.box {align-items: flex-start | flex-end | center | baseline | stretch; } 

它可能取5个值。具体的对齐方式与交叉轴的方向有关,下面假设交叉轴从上到下。

  • flex-start:交叉轴的起点对齐。
  • flex-end:交叉轴的终点对齐。
  • center:交叉轴的中点对齐。
  • baseline: 项目的第一行文字的基线对齐。
  • stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。

3.6 align-content属性

align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。


.box {align-content: flex-start | flex-end | center | space-between | space-around | stretch; } 

该属性可能取6个值。

  • flex-start:与交叉轴的起点对齐。
  • flex-end:与交叉轴的终点对齐。
  • center:与交叉轴的中点对齐。
  • space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。
  • space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。
  • stretch(默认值):轴线占满整个交叉轴。

四、项目的属性

以下6个属性设置在项目上。

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

4.1 order属性

order属性定义项目的排列顺序。数值越小,排列越靠前,默认为0。


.item {order: <integer>; } 

4.2 flex-grow属性

flex-grow属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。


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

如果所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话)。如果一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍。

4.3 flex-shrink属性

flex-shrink属性定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。


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

如果所有项目的flex-shrink属性都为1,当空间不足时,都将等比例缩小。如果一个项目的flex-shrink属性为0,其他项目都为1,则空间不足时,前者不缩小。

负值对该属性无效。

4.4 flex-basis属性

flex-basis属性定义了在分配多余空间之前,项目占据的主轴空间(main size)。浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项目的本来大小。


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

它可以设为跟widthheight属性一样的值(比如350px),则项目将占据固定空间。

4.5 flex属性

flex属性是flex-grow, flex-shrinkflex-basis的简写,默认值为0 1 auto。后两个属性可选。


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

该属性有两个快捷值:auto (1 1 auto) 和 none (0 0 auto)。

建议优先使用这个属性,而不是单独写三个分离的属性,因为浏览器会推算相关值。

4.6 align-self属性

align-self属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch


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

该属性可能取6个值,除了auto,其他都与align-items属性完全一致。

转载于:https://www.cnblogs.com/web928943/p/9981565.html

Flex 弹性盒基本语法相关推荐

  1. flex 会使div撑满_如何讲清楚Flex弹性盒模型(中)?

    上一篇我们讲解了, flex容器的属性, 如何定义主轴方向, 以及主轴侧轴对齐方式 这篇讲解子元素的一些属性. 如何对子项目进行排序? 弹性盒模型第一次可以让我们方便的对元素进行排序 使用 order ...

  2. flex 会使div撑满_如何讲清楚Flex弹性盒模型?(中)

    上一篇我们讲解了, flex容器的属性, 如何定义主轴方向, 以及主轴侧轴对齐方式 这篇讲解子元素的一些属性. 如何对子项目进行排序? 弹性盒模型第一次可以让我们方便的对元素进行排序 使用 order ...

  3. css盒模型、布局模型、 flex弹性盒模型及样式设置小技巧

    一.盒模型 元素分类  常用的块状元素有: <div>.<p>.<h1>...<h6>.<ol>.<ul>.<dl> ...

  4. html-css13 flex弹性盒 W3school导航条另一种写法 淘宝的导航条

    flex弹性盒 <!DOCTYPE html> <html lang="en"><head><meta charset="UTF ...

  5. css3弹性盒模型兼容性,彻底弄懂css3的flex弹性盒模型

    由于在日常工作中使用css或者bootstrap的栅格系统已经能很好的满足业务需求,所以一直以来对css3的弹性布局不是很感冒. 近日有幸在一篇文章中领略了flex的魅力--简洁优雅.随试之. /*容 ...

  6. 粉阿吉整理(6)之------Flex 弹性盒

    1. 怪异盒模型 想写上border和padding,又不想增加的时候,就可以把它变成怪异盒模型 因为怪异盒模型的boder和padding都在内部. 标准盒模型只针对内容的宽度做了一个指定,没有对元 ...

  7. 最流行的布局方案 Flex 弹性盒布局详解

    Flex布局又称弹性盒布局,是在CSS3中的一种新布局方式,可以简洁.方便.响应式地实现各种页面布局,因此自一提出受到了极大地追捧,目前也得到了各大主流浏览器的支持,因此迅速替代了之前的"d ...

  8. CSS 布局 Flex弹性盒

    弹性盒,是一种布局方式,当页面需要适应不同的屏幕大小以及设备类型时,它依然能确保元素拥有更恰当的排布行为,弹性盒属于 CSS 3 部分,IE9 以下不支持,现代浏览器指的就是 IE9 及以上的浏览器 ...

  9. css flex: 2;,CSS 布局_2 Flex弹性盒

    Unsplash 弹性盒,是一种布局方式,当页面需要适应不同的屏幕大小以及设备类型时,它依然能确保元素拥有更恰当的排布行为,从定义方面来说,弹性布局是指通过调整其内元素的宽高,从而在任何显示设备上实现 ...

最新文章

  1. MySQL隐式转化整理
  2. 《Linux内核设计的艺术:图解Linux操作系统架构设计与实现原理》——2.15 本章小结...
  3. TComboBox下拉取值
  4. DATA URI schema(data:base64)协议常用数据格式
  5. 微信跳一跳高分系列二:adb shell 中的常用命令
  6. Docker 第四章 访问容器
  7. EXPORT_SYMBOL
  8. java oracle.sql.struct转字符串_JAVA oracle.sql.OPAQUE转String
  9. 图片上传工具 java_图片上传工具类-fileUtil
  10. arcgis 经纬度转大地坐标_【干货】坐标系统与投影变换及在ArcGIS中的应用
  11. vue从入门到开发--2-基本结构
  12. linux指令格式介绍
  13. 兰州大学计算机基础在线考试,[兰州大学]《计算机基础》2020年5月考试在线考核试题...
  14. 【Python数据分析】数据挖掘建模——分类与预测算法评价(含ROC曲线、F1等指标的解释)
  15. 三相PWM整流器dq解耦控制
  16. 三维GIS软件十九重唱
  17. Ubuntu 分卷压缩
  18. 菊花是哪个城市的市花1_2.html,菊花的季节作文
  19. java登录无线路由器_获取WiFi路由器的唯一标识符
  20. JavaScript复习

热门文章

  1. 装了BT5后要做的几件事
  2. 函数调用时栈的相关变化
  3. 北京超前布局通用人工智能 我国首个超大规模智能模型系统发布
  4. 程序员应该学习C语言的十个理由
  5. mysql 三层架构开发_从三层架构迈向领域驱动设计(转载)
  6. python 断点重传_性能调优-python SDK 调优
  7. EL 表达式 JSTL 标签库
  8. 023_JavaScript数字方法
  9. android web 打印,Android设备WebView打印Console Log
  10. linux 硬件抽象,Linux 内核硬件抽象