CSS3弹性盒模型的布局理解

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CSS3弹性盒模型的布局理解相关的知识,希望对你有一定的参考价值。

参考技术A 什么是flex布局?

传统的布局方案是基于盒模型,依赖于display:block和float+position,但是对于一些特殊的布局来说就不是很方便,如在盒模型中垂直居中。

2009年W3C提出一种新的布局方案,flex弹性盒布局,目前兼容的浏览器有chrome opera IE Firefox Sifari 

flex兼容浏览器版本

但是在未来flex布局将会成为布局的首选方案。

flex是flexinle BOX的缩写。意思是弹性布局,用来为盒模型提供最大的灵活性。    任何一个容器(标签)都可以指定为flex布局。用display:flex;

如果给容器设置flex的时候当前容器内子元素的float,clear,vericla-align都将会失效

flex的基本概念

容器默认存在两根轴:水平的主轴(main axis)和垂直交叉轴(cross axis).主轴的开始位置(与边框的交叉点)叫做main start, 结束位置叫做main end ;交叉轴的开始位置叫做cross start ,结束位置叫做cross end.项目默认沿主轴排列。单个项目占据的主轴空间叫做main size,占据的交叉轴叫做cross size.

如果给一个元素设置为flex后,这个元素就会作为子元素的flex容器。通过给容器设置属性来改变里面子元素的位置。



首先要给父元素添加display:flex;将父元素转化为弹性盒

2.用flex-direction来改变盒子里元素的位置

row 默认在一行内排列(从左向右)

row-reverse:反转横向排列(右对齐,从后往前排,最后一项排在最前面。)

column :纵向排列。

column-reverse:反转纵向排列,从下往上排,最后一项排在最上面

3.内容对齐(justify-content)属性应用在 弹性容器 上,把弹性项沿着弹性容器的主轴线(main axis)对齐

justify-content:flex-start 默认,左对齐(图1)

justify-content:flex-end 右对齐(图2)

justify-content:center 居中对齐(图3)

justify-content:space-between 两端对齐,中间自动分配

justify-content:space-around 自动分配距离

主轴对齐方式

4.align-items(交叉轴对齐方式)

flex-start:顶端对齐

flex-end:底对齐

center:垂直居中对齐

baseline:项目内文本的底线对齐

stretch  默认值    项目的高度自适应容器(注:子元素不能设置高)

交叉轴对齐方式

5.flex-wrap

该属性控制flex容器是单行或者多行,同时横轴的方向决定了新行堆叠的方向。

  nowrap:flex容器为单行。该情况下flex子项可能会溢出容器

  wrap:flex容器为多行。该情况下flex子项溢出的部分会被放置到新行,子项内部会发生断行

  wrap-reverse:反转 wrap 排列。

图1(nowrap)注意如果父元素盒设置宽度会自动缩子元素容器宽度

图2(wrap)

图3(warp-reverse)

容器单行或者多行方式

 6、align-content(行与行之间对齐方式)

当伸缩容器的侧轴还有多余空间时,本属性可以用来调整「伸缩行」在伸缩容器里的对齐方式,这与调整伸缩项目在主轴上对齐方式的 <‘ justify-content’> 属性类似。 注:本属性在只有一行的伸缩容器上没有效果。

flex-start没有行间距

flex-end底对齐没有行间距

center居中没有行间距

space-between两端对齐,中间自动分配

space-around自动分配距离

深入理解CSS弹性盒模型flex

前面的话

  CSS3引入了一种新的布局模型——flex布局。flex是flexible box的缩写,一般称之为弹性盒模型。和CSS3其他属性不一样,flexbox并不是一个属性,而是一个模块,包括多个CSS3属性。flex布局提供一种更加有效的方式来进行容器内的项目布局,以适应各种类型的显示设备和各种尺寸的屏幕

 

版本更迭

  flexbox布局的语法规范经过几年发生了很大的变化。从2007年07月,flex第一版本的工作草案发布,到2012年09月,flex最新版本成为候选推荐。flex主要经历了三个版本

【1】旧版本 display:box | inline-box;

  该版本IE浏览器不支持,且其他浏览器和移动端都需要添加前缀,但移动端可以兼容到andriod2.1和ios3.2

【2】混合版本 display:flexbox | inline-flexbox;

  该版本只有IE10支持,且需要添加前缀-ms-

【3】新版本 display: flex | inline-flex

  该版本兼容IE11+、firefox、safari、chrome、opera及移动端,但移动端ios7.1-8.4需要添加前缀-webkit-

 

display

  要让一个元素变成伸缩容器,需要使用display属性。采用flex布局的元素,称为伸缩容器(flex container),容器内的子元素称为伸缩项目(flex item)

  [注意]浏览器会将任何直接在伸缩容器里的连续文字块包起来成为匿名伸缩项目

  使用flex布局实现上是使元素FFC化(flex formatting context伸缩格式化上下文),FFC是普通流的一种。而浮动流和定位流以及CSS其他属性对FFC是有影响的,主要表现在以下几点:

  [1]float、clear和vertical-align属性在伸缩项目上没有效果

  [2]伸缩容器的margin与其内容的margin不会重叠

  [3]text-align属性在伸缩容器上没有效果,因为其只可应用于块级block容器

  [4]另外,conlumns属性伸缩容器上没有效果

  弹性盒模型的两种容器块级伸缩容器和内联伸缩容器的区别类似于block和inline-block的区别,一个独占一行,另一个非独占一行

//弹性盒模型: 块级伸缩容器 | 内联伸缩容器
//新版本
display: flex | inline-flex;
//混合版本
display: flexbox | inline-flexbox;
//旧版本
display: box | inline-box;

 

基本概念

技术分享

  伸缩容器默认存在两条轴: 水平的主轴(main axis) 和垂直的侧轴(cross axis)

  [注意]主轴方向不一定是水平的,它主要取决于justify-content属性

  主轴起点叫main start,主轴终点叫main end;侧轴起点叫cross start,侧轴终点叫cross end

  伸缩项目默认沿主轴排列。单个伸缩项目占据的主轴空间叫main size ,占据的侧轴空间叫cross size

  [注意]伸缩项目的main size和cross size主要由宽度或高度决定

 

伸缩容器

  以下6个属性作用在伸缩容器上

  伸缩流方向 flex-direction

  伸缩流换行 flex-wrap

  伸缩流(包括方向与换行) flex-flow

  主轴对齐 justify-content

  侧轴对齐 align-items

  堆栈伸缩行 align-content

【1】伸缩流方向:指定主轴的方向(即伸缩项目在伸缩容器中的排列方向)

//伸缩流方向: 水平方向 | 反向水平 | 垂直方向 | 反向垂直
//新版本同混合版本
flex-direction: row[默认] | row-reverse | column | column-reverse
//旧版本
box-orient: horizontal(水平) |vertical(垂直) |inline-axis[默认](内联轴方向) |block-axis(块级轴方向)
box-direction: normal(正常) | reverse(反向) 

  [注意]伸缩流方向与direction和wrinting-mode有关系

【2】伸缩流换行:指定伸缩项目溢出伸缩容器时是否换行

//伸缩行换行:不换行 | 换行 | 反转换行
//新版本同混合版本
flex-wrap: nowrap[默认] | wrap | wrap-reverse
//旧版本,没有浏览器支持box-lines属性,所以在旧版本中无法实现伸缩项目换行显示
box-lines: single[默认] | multiple | N/A

  [注意]此时,CSS允许使用overflow属性来处理溢出内容的显示方式

  [注意]伸缩项目的排列顺序同样与direction和wrinting-mode有关系

【3】伸缩流:伸缩流方向与伸缩行换行的缩写

//伸缩流: 伸缩流方向 | 伸缩行换行
//新版本同混合版本
flex-flow: <flex-direction> | <flex-wrap> 
[默认值] flex-flow: row nowrap
//旧版本无对应属性

【4】主轴对齐:用来设置伸缩容器当前行伸缩项目在主轴方向的对齐方式,指定如何在伸缩项目之间分布伸缩容器额外空间

  当一行上的所伸缩项目不能伸缩或可伸缩已达到最大长度时,这一属性才会对伸缩容器额外空间进行分配。当伸缩项目溢出某一行时,这一属性也会在项目的对齐上施加一些控制

//主轴对齐方式: 左对齐 | 居中对齐 | 右对齐 | 两端对齐 | 扩散对齐
//新版本
justify-content: flex-start[默认] | center | flex-pack | flex-end | space-around
//混合版本
flex-pack: start[默认] | center | end | justify | distribute
//旧版本
box-pack: start[默认] | center | end | justify | N/A

  [注意]主轴对齐方式与direction、writing-mode、flex-flow都有关

【5】侧轴对齐:用来设置伸缩容器当前行在侧轴方向的对齐方式

//侧轴对齐方式: 顶边对齐 | 中间对齐 | 底部对齐 | 基线对齐 | 伸缩项目拉伸填充整个伸缩容器
//新版本
align-items: flex-start | center | flex-end | baseline | stretch[默认]
//混合版本
flex-align: start | center | end | baseline | stretch[默认]
//旧版本
box-align: start | center | end | baseline | stretch[默认]

  [注意]如果伸缩项目有width/height属性将优先于侧轴对齐为拉伸的方式

  [注意]侧轴对齐方式与direction、writing-mode、flex-flow都有关

【6】堆栈伸缩行:指定多个伸缩项目行在侧轴的对齐方式

//侧轴对齐方式: 顶边对齐 | 中间对齐 | 底部对齐 | 两端对齐 | 扩散对齐 | 伸缩项目拉伸填充整个伸缩容器
//新版本
align-content: flex-start | center | flex-end | space-between | space-around | stretch[默认]
//混合版本
flex-line-pack: start | center | end | justify | distribute | stretch[默认]
//旧版本无对应属性

  [注意]该属性只有在flex-wrap:wrap | wrap-reverse;且伸缩项目存在多行时才生效

  [注意]堆栈伸缩行与direction、writing-mode、flex-flow都有关

 

伸缩项目

  一个伸缩项目就是伸缩容器的一个子元素。伸缩容器中的文本也被视为一个伸缩项目。以下6个属性设置在伸缩项目上。

  自身侧轴对齐方式 align-self

  伸缩基准值 flex-basis

  扩展比率 flex-grow

  收缩比率 flex-shrink

  伸缩性 flex

  显示顺序 order

【1】自身侧轴对齐方式:单个伸缩项目在侧轴的对齐方式,该属性可以覆盖伸缩容器的侧轴对齐方式

  [注意]对于匿名伸缩项目,align-self的值永远与其关联的伸缩容器的align-items的值相同

//侧轴对齐方式: 自动 | 顶边对齐 | 中间对齐 | 底部对齐 | 基线对齐 | 伸缩项目拉伸填充整个伸缩容器
//新版本
align-self: auto[默认] | flex-start | center | flex-end | baseline | stretch
//混合版本
flex-item-align: auto[默认] | start | center | end | baseline | stretch
//旧版本无对应属性

  [注意]如果align-self的值为auto,则其计算值为伸缩项目的伸缩容器的align-items值

  [注意]如果伸缩项目的任一个侧轴上的外边距为auto,则该伸缩项目在伸缩容器的剩余空间内居中对齐,且align-self没有效果。

【2】伸缩基准值: 伸缩项目在主轴方向上的初始大小

//新版本
flex-basis: <length> | auto[默认]
//混合版本
positive-flex: <number>[默认为1]
//旧版本无对应属性

  如果flex-basis的值为0,表示伸缩项目在主轴方向上的初始大小为0,则分配所有空间;如果flex-basis的值为auto,表示伸缩项目在主轴方向上的初始大小为其本身的大小,则分配剩余空间

  [注意]flex-basis的<length>值可以是一个数字后面跟着px、em等单位,也可以是一个百分数,相对于其父伸缩容器的主轴长度

 【3】扩展比率: 当伸缩容器的额外空间为正值时,此伸缩项目相对伸缩容器里其他伸缩项目能扩展的空间比例

//新版本
flex-grow: <number>[默认为0]
//混合版本
positive-flex: <number>[默认为0]
//旧版本无对应属性

  若flex-grow的值为0表示即使存在剩余空间也不放大;若所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话);若一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍

【4】收缩比率:当伸缩容器的额外空间为负值时,此伸缩项目相对于伸缩容器里其他伸缩项目能收缩的空间比例

//新版本
flex-shrink: <number>[默认为1]
//混合版本
negative-flex: <number>[默认为0]
//旧版本无对应属性

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

  [注意]伸缩基准值、扩展比率和收缩比率都可以为小数,但不能为负数

【5】伸缩性:是扩展比率、收缩比率和伸缩基准值的缩写

    flex: none => flex: 0 0 auto;
    flex: auto => flex: 1 1 auto;
    flex: 0 => flex: 0 1 0%;
    flex: 1 => flex: 1 1 0%;
    flex: 0 auto => flex: 0 1 auto;
    flex: 0 1 => flex: 0 1 0%;

  [注意]当flex为关键字none或存在auto时,flex-basis为auto;若flex只有数字值,则flex-basis为0%;

//新版本
flex: none[默认] | [<flex-grow> <flex-shrink>? || <flex-basis>]
//混合版本
flex: none[默认] | [<pos-flex> <neg-flex>? || <preferred-size>]
//旧版本
box-flex: <number>[默认为0]

【6】显示顺序: 定义伸缩项目的排列顺序,数值越小,排列越靠前

  [注意]伸缩容器中的伸缩项目默认显示顺序是遵循文档在源码中出现的先后顺序(HTML文档的DOM结构中的先后顺序)

//新版本
order: <number>[默认为0]
//混合版本
flex-order: <number>[默认为0]
//旧版本
box-ordinal-group: <integer>[默认为1]

  [注意]order的属性值可以是负数,但不能是小数

以上是关于CSS3弹性盒模型的布局理解的主要内容,如果未能解决你的问题,请参考以下文章

深入理解CSS弹性盒模型flex

弹性盒模型flex

CSS布局盒模型CSS3弹性盒模型

CSS3弹性盒模型flexbox布局基础版

css3盒模型和弹性布局的相关属性

弹性盒模型-CSS3