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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,948评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,371评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,490评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,521评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,627评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,842评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,997评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,741评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,203评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,534评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,673评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,339评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,955评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,770评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,000评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,394评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,562评论 2 349