移动端布局flex

移动端布局flex_第1张图片
可以看阮一峰老师写的Flex 布局教程:语法篇非常清晰

为什么引入flex布局

传统布局的优缺点:

  • 兼容性好
  • 布局繁琐
  • 局限性,不能在移动端很好布局
    flex布局的优缺点
  • 操作方便,布局简单,移动端使用广泛
  • PC端浏览器支持情况较差
  • 低版本浏览器不支持flex

flex布局如何实现?

flex 是 Flexible Box 的缩写,意为"弹性布局"。指定容器display: flex即可。
Flex是Flexible Box的缩写,意为”弹性布局”,用来为盒状模型提供最大的灵活性。
任何一个容器都可以指定为Flex布局。容器分为两种,块flex和行内flex.

.box{
  display:flex;/*webkit需要加前缀*/
  /*display:inline-flex;*/
}

Flex布局有两层,采用flex布局的元素称为flex容器,其子元素则自动成flex item,即项目.
注:flex不同于block,flex容器的子元素的float,clear,vertical-align属性将失效.

  • 容器有以下属性:

flex-direction,flex-wrap,flex-flow,justify-content,align-items,align-content。

flex-direction属性决定主轴的方向;
flex-wrap属性定义,如果一条轴线排不下,如何换行;
flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap;
justify-content属性定义了项目在主轴上的对齐方式。
align-items属性定义项目在交叉轴上如何对齐。
align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。

  • 项目(子元素)也有一些属性:

order,flex-grow,flex-shrink,flex-basis,flex,align-self。

order属性定义项目的排列顺序。数值越小,排列越靠前,默认为0。
flex-grow属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。
flex-shrink属性定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。
flex-basis属性定义了在分配多余空间之前,项目占据的主轴空间(main size)。
flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。
align-self属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。

你可能感兴趣的:(html5)