Flexbox弹性盒子

什么是flexbox

定义一个flex box(伸缩盒布局),需要在一个父级元素上使用display属性的值:flexinline-flex。这个父级元素将成为flex container(伸缩容器),而它的所有子元素将变成flex item(伸缩项)。

使用flex 值能将元素渲染成为一个块级容器,而使用inline-flex值则是渲染成一个行内伸缩容器。这些值会将元素格式化,产生flex formatting context(伸缩格式化上下文),这类似于块的格式化上下文,而浮动不会干扰容器,且容器的margins(所有边距)不会随着这些项目被折叠。

 有的地方叫做伸缩盒子,有的地方叫做弹性盒子,还有的叫做灵活性盒子。这些叫法都是说的名为flexbox的一种css3中的容器。作用是为了用来为盒模型提供最大的灵活性,不论是间隔方式,对齐方式等等都变得极为灵活,基本上可以实现任何你想要的布局方式。本文暂且将flexbox称为弹性盒子。

任何一种元素我们都可以为指定成为flex布局,块级元素或者行级元素都可以。

.block-box{
  display: flex;
}
.inline-box{
  display: inline-flex;
}

弹性盒子的几个关键词

  • flex容器(flex container)
  • flex元素(flex item)
  • 主轴(main axis)
  • 交叉轴(cross asix)

根据如上关键词,我们要从中记住几个flexbox的关键要素

  • 每一个flexbox都会两根轴,一根为主轴,一根为交叉轴,两轴为像一个基础坐标轴一样成90°的关系,并且主轴可以根据属性变换。flex item会根据轴向进行排列。
  • 每根轴会有起点,中点和终点。

flex container的六大属性

flex-direction

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

flex-wrap

nowrap(默认):不换行。

wrap:换行,第一行在上方。

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

flex-flow

justify-content

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

align-items

 

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

align-content

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

你可能感兴趣的:(css)