css-flex布局笔记

第一章:简介

Flex:FlexiableBox(弹性盒,伸缩盒)

它是css中又一种布局手段,它主要用来代替传统浮动来进行页面布局

css布局的传统解决方案:基于盒子模型,使用display属性 +position属性 +float属性。对于那些特殊布局非常不方便,比如,垂直居中就不容易实现。

2009年,W3C提出了一种新的方案—-Flex布局,可以简便、完整、响应式地实现各种页面布局。目前,它已经得到了大部分浏览器的支持,特别是在移动端开发,flex布局是一种很常用的布局手段,是每一个前端开发者必须掌握的技能

第二章:概念

flex布局中有两个非常重要的概念:弹性容器弹性元素

弹性容器

     - 要使用弹性盒,必须先将一个元素设置为弹性容器

     - 我们通过 display 来设置弹性容器

           display:flex  设置为块级弹性容器

           display:inline-flex 设置为行内弹性容器

弹性元素

        - 弹性容器的子元素是弹性元素(也称做弹性项)

        - 一个元素可以同时是弹性容器和弹性元素

主轴和侧轴(辅轴)的概念

主轴:弹性元素的排列方向称为主轴,主轴有可能是水平的,有可能是垂直的,主轴有一个方向,有可能是自左向右,有可能自上向下....

侧轴:与主轴垂直方向的称为侧轴 

第三章:样式

弹性布局的样式总共分为两类:一个专门给弹性容器设置,一类专门给弹性元素设置

学习第一个弹性容器的样式属性

flex-direction 用来指定容器中弹性元素的排列方式

可选值:

row 默认值,弹性元素在容器中水平排列(左向右)

     - 主轴 自左向右

row-reverse 弹性元素在容器中反向水平排列(右向左)

     - 主轴 自右向左

column 弹性元素纵向排列(自上向下)

     - 主轴 自上向下

column-reverse 弹性元素反向纵向排列(自下向上)

     - 主轴 自下向上

学习两个弹性元素的样式属性

flex-grow 

    - 指定弹性元素的伸展的系数,默认是0

    - 当父元素有多余的空间时,子元素如何伸展

    - 父元素的剩余空间,会按照比例进行分配

flex-shrink 

    - 指定弹性元素的收缩系数

    - 当父元素中的空间不足以容纳所有的子元素时,如何对子元素进行收缩,默认值是1

    - 这两个属性可以分别给每个子元素设置

利用弹性盒做一个简单的导航条

弹性容器的样式

flex-wrap:

设置弹性元素是否在弹性容器中自动换行

可选值:

    nowrap 默认值,元素不会自动换行

    wrap 元素沿着辅轴方向自动换行

    wrap-reverse 表示元素沿着辅轴反方向换行

flex-flow

wrap 和 direstion 的简写属性(可以同时设置两个属性并且没有顺序要求)

例如:flex-flow:wrap row;    设置子元素在水平方向自左向右排列,并且当父元素宽度不足以容纳子元素时子元素自动换行

justify-content

- 如何分配主轴上的空白空间(主轴上的元素如何排列)

- 可选值:

    fiex-start 元素沿着主轴的起边排列

    flex-end 元素沿着主轴的终边排列

    center 元素居中排列

    space-around 空白分布到元素两侧

    space-between 空白均匀分布到元素间

    space-evenly 空白分布到元素的单侧

align-items

  - 元素在辅轴上如何对齐

  - 元素间的关系

   - 可选值

        stretch 默认值,将元素的长度设置为相同的值(会拉伸元素)

        flex-start 元素不会拉伸,沿着辅轴起边对齐

        flex-end 沿着辅轴终边对齐

        center 居中对齐

        baseline 基线对齐(用得很少)

align-content(属性值和justify-content的属性值一样)

    - 如何分配辅轴上的空白空间(辅轴上的元素如何排列)

    - 可选值:

        fiex-start 元素沿着辅轴的起边排列

        flex-end 元素沿着辅轴的终边排列

        center 元素居中排列

        space-around 空白分布到元素两侧

        space-between 空白均匀分布到元素间

        space-evenly 空白分布到元素的单侧

这里掺杂一个弹性元素的属性
align-self

- 用来覆盖当前弹性元素上的align-items,取值和align-items一样

    stretch 默认值,将元素的长度设置为相同的值(会拉伸元素)

    flex-start 元素不会拉伸,沿着辅轴起边对齐

    flex-end 沿着辅轴终边对齐

    center 居中对齐

    baseline 基线对齐(用得很少)

弹性元素的样式

弹性元素的样式相对于弹性容器来说就比较简单了

align-self 

    前面已经介绍了,这里就省略了

flex-grow

    弹性的增长系数,默认值是0,不增长

flex-shrink

  弹性元素的缩进系数,默认值是1

       - 缩减系数的计算方式比较复杂

       - 缩减多少是根据缩减系数和元素大小来计算

flex-basis 

        指定的是元素在主轴上的基础长度

        如果主轴是 横向的 则该值指定的就是元素的宽度

        如果主轴是 纵向的 则该值指定的就是元素的高度

          - 默认值是 auto,表示参考元素自身的高度或宽度

          - 如果传递了一个具体的值,则以该值为准

!!! flex-basis       flex-shrink     flex-grow这三个属性就类似弹簧的三种状态:静止、收缩和拉伸

flex 

   可以设置弹性元素所有的三个样式

   flex 增长 缩减 基础;

   initial "flex: 0 1 auto"

   auto "flex: 1 1 auto"

   none "flex: 0 0 auto" 弹性元素没有弹性

    !!!注意一点:flex:1和flex-grow:1之间的是有区别的

    flex:1会设置flex-basis:0,也就是说元素设置flex属性,它的宽度或者高度就会变成0

    而flex-grow:1不会设置flex-basis,flex-basis的值还是默认的auto

order 

        - 决定弹性元素的排列顺序

        - 可以通过order来影响元素的排列顺序,这是一个非常强大的功能

        - 有了它之后,我们就不需要通过结构去调整元素的顺序

        - 只需要通过order这个属性就可以改变元素的顺序

第四章:总结

flex布局可以很方便实现网页元素的布局,可以搭配百分比,rem等来实现各类布局,是一种可以代替传统浮动布局的手段,整体知识点不难,只是属性较多,弹性容器和弹性元素分别都有六个属性,以及它们各自的取值,需要多加练习才能掌握

弹性容器的六个属性
项目(弹性元素)的六个属性

也可以参考阮一峰老师的这篇博客教程http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。