|Flex布局入门分享

文章图片

文章图片

文章图片

文章图片

文章图片

文章图片

文章图片

文章图片
自从css3有了Flex , 从此布局是浮云 , 本文全面的讲解了Flex布局的属性 , 帮助你快速入门Flex布局 , 一起来看看这篇Flex布局入门教程 。
网页布局(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{行内元素也可以使用 Flex 布局 。
display: flex;
.box{Webkit 内核的浏览器 , 必须加上
display: inline-flex;
-webkit前缀 。.box{注意 , 设为 Flex 布局以后 , 子元素的
display: -webkit-flex; /* Safari */
display: flex;
float、clear和vertical-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个属性设置在容器上 。
3.1 flex-direction属性
- flex-direction
- flex-wrap
- flex-flow
- justify-content
- align-items
- align-content
flex-direction属性决定主轴的方向(即项目的排列方向) 。.box {
flex-direction: row | row-reverse | column | column-reverse;
它可能有4个值 。
3.2 flex-wrap属性默认情况下 , 项目都排在一条线(又称\"轴线\")上 。
row(默认值):主轴为水平方向 , 起点在左端 。
row-reverse:主轴为水平方向 , 起点在右端 。
column:主轴为垂直方向 , 起点在上沿 。
column-reverse:主轴为垂直方向 , 起点在下沿 。
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 {3.4 justify-content属性
flex-flow: <flex-direction> || <flex-wrap>;
justify-content属性定义了项目在主轴上的对齐方式 。.box {
justify-content: flex-start | flex-end | center | space-between | space-around;
它可能取5个值 , 具体对齐方式与轴的方向有关 。 下面假设主轴为从左到右 。
3.5 align-items属性
flex-start(默认值):左对齐
flex-end:右对齐
center: 居中
space-between:两端对齐 , 项目之间的间隔都相等 。
space-around:每个项目两侧的间隔相等 。 所以 , 项目之间的间隔比项目与边框的间隔大一倍 。
align-items属性定义项目在交叉轴上如何对齐 。.box {
align-items: flex-start | flex-end | center | baseline | stretch;
它可能取5个值 。 具体的对齐方式与交叉轴的方向有关 , 下面假设交叉轴从上到下 。
3.6 align-content属性
flex-start:交叉轴的起点对齐 。
flex-end:交叉轴的终点对齐 。
center:交叉轴的中点对齐 。
baseline: 项目的第一行文字的基线对齐 。
stretch(默认值):如果项目未设置高度或设为auto , 将占满整个容器的高度 。
align-content属性定义了多根轴线的对齐方式 。 如果项目只有一根轴线 , 该属性不起作用 。.box {
align-content: flex-start | flex-end | center | space-between | space-around | stretch;
该属性可能取6个值 。
四、项目的属性以下6个属性设置在项目上 。
flex-start:与交叉轴的起点对齐 。
flex-end:与交叉轴的终点对齐 。
center:与交叉轴的中点对齐 。
space-between:与交叉轴两端对齐 , 轴线之间的间隔平均分布 。
space-around:每根轴线两侧的间隔都相等 。 所以 , 轴线之间的间隔比轴线与边框的间隔大一倍 。
stretch(默认值):轴线占满整个交叉轴 。
4.1 order属性
order
flex-grow
flex-shrink
flex-basis
flex
align-self
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 , 即如果空间不足 , 该项目将缩小 。//code from http://caibaojian.com/flexbox-basic-tourial.html.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 */
width或height属性一样的值(比如350px) , 则项目将占据固定空间 。4.5 flex属性
flex属性是flex-grow flex-shrink 和 flex-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属性完全一致 。
【|Flex布局入门分享】
来源:前端开发博客
推荐阅读
- 看观汽车|原装进口发动机,入门7万出头,看着动感坐着舒适,丰田致享如何
- 德媒:中国为与美国“大脱钩”布局,真要脱钩全球都要受伤
- 猫眼|猫眼中报:强化布局 助力行业 短期影响未改长期逻辑
- 码头|洋码头发布“三新战略”,线下实体店、直播成布局重点
- 衣帽间|衣帽间装修怎样做,衣帽间布局有哪些
- 奔驰G级入门版售价曝光!售价或不过百万元/9月上市
- 电竞|联众国际副总裁吴巍巍出席“电竞北京2020”谈差异化布局征战海外
- 举办线上演出布局社交空间 在线音乐平台探索新生态
- 城市营销|巨量引擎城市峰会首站启幕,多元化布局引领城市品牌营销新趋势
- 送皮肤和入门包!《Jump大乱斗》早期预购特典公布
