CSS flex布局 (弹性布局)

1. 基本概念

采用 Flex 布局的元素,称为 Flex 容器(flex container),简称“容器”。它的所有子元素自动成为容器成员,称为 Flex 项目(flex item),简称“项目”。容器默认存在两根轴,分别为水平的主轴(main axis)和垂直的交叉轴(cross axis)。主轴的开始位置叫做 main start,结束位置叫做 main end;交叉轴的开始位置叫做 cross start,结束位置叫做 cross end。项目默认沿主轴排列。单个项目占据的主轴空间叫做 main size,占据的交叉轴空间叫做 cross size。如下图所示:
 

 

弹性盒布局:

属性

描述

display

指定 HTML 元素的盒子类型

flex-direction

指定弹性盒子中子元素的排列方式

flex-wrap

设置当弹性盒子的子元素超出父容器时是否换行

flex-flow

flex-direction 和 flex-wrap 两个属性的简写

justify-content

设置弹性盒子中元素在主轴(横轴)方向上的对齐方式

align-items

设置弹性盒子中元素在侧轴(纵轴)方向上的对齐方式

align-content

修改 flex-wrap 属性的行为,类似 align-items,但不是设置子元素对齐,而是设置行对齐

order

设置弹性盒子中子元素的排列顺序

align-self

在弹性盒子的子元素上使用,用来覆盖容器的 align-items 属性

flex

设置弹性盒子中子元素如何分配空间

flex-grow

设置弹性盒子的扩展比率

flex-shrink

设置弹性盒子的收缩比率

flex-basis

设置弹性盒子伸缩基准值

justify-content:

用于设置弹性盒子中元素在主轴(横轴)方向上的对齐方式,属性可选值如下:

描述

flex-start

默认值,左对齐

flex-end

右对齐

center

居中

space-between

两端对齐,项目之间的间隔是相等的

space-around

每个项目两侧的间隔相等

initial

将此属性设置为属性的默认值

inherit

从父元素继承属性的值

flex-direction

flex-direction 属性用来决定主轴的方向(即项目的排列方向),属性的可选值如下:

描述

row

默认值,主轴沿水平方向从左到右

row-reverse

主轴沿水平方向从右到左

column

主轴沿垂直方向从上到下

column-reverse

主轴沿垂直方向从下到上

initial

将此属性设置为属性的默认值

inherit

从父元素继承此属性的值

flex-wrap

flex-wrap 属性用来设置当弹性盒子的子元素(项目)超出父容器时是否换行,属性的可选值如下:

描述

nowrap

默认值,表示项目不会换行

wrap

表示项目会在需要时换行

wrap-reverse

表示项目会在需要时换行,但会以相反的顺序

initial

将此属性设置为属性的默认值

inherit

从父元素继承属性的值

align-items

align-items 属性用来设置弹性盒子中元素在侧轴(纵轴)方向上的对齐方式,属性的可选值如下:

描述

stretch

默认值,项目将被拉伸以适合容器

center

项目位于容器的中央

flex-start

项目位于容器的顶部

flex-end

项目位于容器的底部

baseline

项目与容器的基线对齐

initial

将此属性设置为属性的默认值

inherit

从父元素继承属性的值

align-content

align-content 属性与 justify-content 属性类似,可以在弹性盒子的侧轴还有多余空间时调整容器内项目的对齐方式,属性的可选值如下:

描述

stretch

默认值,将项目拉伸以占据剩余空间

center

项目在容器内居中排布

flex-start

项目在容器的顶部排列

flex-end

项目在容器的底部排列

space-between

多行项目均匀分布在容器中,其中第一行分布在容器的顶部,最后一行分布在容器的底部

space-around

多行项目均匀分布在容器中,并且每行的间距(包括离容器边缘的间距)都相等

initial

将此属性设置为属性的默认值

inherit

从父元素继承该属性的值

align-self

align-self 属性允许您为某个项目设置不同于其它项目的对齐方式,该属性可以覆盖 align-items 属性的值。align-self 属性的可选值如下:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值