zoukankan      html  css  js  c++  java
  • Flex 布局的教程

    前言:以前也经常用flex布局,但是最近看到别人使用的时候,发觉以前自己还是不够理解这个,重新看了一遍http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

    一、Flex 布局是什么?

    Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供很大灵活性。

    所有容器都可以指定为flex布局

    .box{
      display: flex;
    }
    

    行内元素也可以

    .box{
      display:inline- flex;
    }
    

    如果是Webkit 内核的浏览器,加上-webkit前缀

    .box{
      display: -webkit-flex; /* Safari */
      display: flex;
    }
    

    ps:设为 Flex 布局以后,子元素的floatclearvertical-align属性将失效。

    二、基本概念

    采用 Flex 布局的元素,称为 Flex 容器(flex container),简称"容器"。其他概念我就不详述了。

    三、容器的属性

    以下6个属性设置在容器上。

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

    flex-direction属性

    flex-direction属性决定主轴的方向(即项目的排列方向)。

    .box {
      flex-direction: row | row-reverse | column | column-reverse;
    }
    row(默认值):主轴为水平方向,起点在左端。
    row-reverse:主轴为水平方向,起点在右端。
    column:主轴为垂直方向,起点在上沿。
    column-reverse:主轴为垂直方向,起点在下沿。
    

    flex-wrap属性

    .box{
      flex-wrap: nowrap | wrap | wrap-reverse;
    }
    
    nowrap(默认):不换行
    wrap:换行,第一行在上方。
    wrap-reverse:换行,第一行在下方。
    

    flex-flow

    flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。
    .box {
      flex-flow: <flex-direction> || <flex-wrap>;
    }
    

    justify-content属性

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

     align-items属性

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

     align-content属性

    ps:align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。(跟上面一样)

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

     项目属性(子元素上的)

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

    order属性

    ps:order属性定义项目的排列顺序。数值越小,排列越靠前,默认为0。

    .item {
      order: <integer>;
    }
    

    flex属性

    flex属性是flex-growflex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。

    .item {
      flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
    }

    该属性有两个快捷值:auto (1 1 auto) 和 none (0 0 auto)。

    建议优先使用这个属性,而不是单独写三个分离的属性,因为浏览器会推算相关值。

    css3 flex属性flex-grow、flex-shrink、flex-basis学习笔记
    最近在研究css3的flex。遇到的flex:
    1;这一块,很是很纠结,flex-grow、flex-shrink、flex-basis始终搞不清,最经搜集了大量的介绍,应该能算是明白了。 网上大部分解释是 flex-grow 是扩展比率 flex-shrink 是收缩比率 flex-basis 伸缩基准值 假设flex盒子父级宽度固定为800px; Flex-grow、Flex-shrink、Flex-basis 是Flex属性的分写模式; 如 .box { flex: 4 3 100px; } 等于 .box { flex-grow: 4; flex-shrink: 3; flex-basis: 100px; } 看以下例子 <div class="flex-parent"> <div class="flex-son"></div> <div class="flex-son"></div> <div class="flex-son"></div> </div> <style type="text/css"> .flex-parent { 800px; } </style> 第一种情况 flex-parent 是父级,而且他的宽度是固定为800px,不会改变; 开始设置子级flex属性; <style type="text/css"> .flex-son:nth-child(1){ flex: 3 1 200px; } .flex-son:nth-child(2){ flex: 2 2 300px; } .flex-son:nth-child(3){ flex: 1 3 500px; } </style> flex-basis总和加起来为1000px; 那么 1000px > 800px (父级的宽度);子元素势必要压缩;溢出了200px; son1 = (flex-shrink) * flex-basis; son2 = (flex-shrink) * flex-basis; ….. sonN = (flex-shrink) * flex-basis; 如果flex-basis的总和加起来大于父级宽度,子级被压缩,最后的选择是flex-shrink来进行压缩计算 加权值 = son1 + son2 + …. + sonN; 那么压缩后的计算公式就是 压缩后宽度 w = (子元素flex-basis值 * (flex-shrink)/加权值) * 溢出值 所以最后的加权值是 1*200 + 2*300 + 3*500 = 2300px son1的扩展量:(200 * 1/ 2300) * 200,即约等于17px; son2的扩展量:(300 * 2/ 2300) * 200,即约等于52px; son3的扩展量:(500 * 3/ 2300) * 200,即约等于130px; 最后son1、son2、son3,的实际宽度为: 20016 = 184px; 30052 = 248px; 500 – 130 = 370px; 第二种情况 上面的例子已经说明,继续看第二个例子,同样上面的例子,我们改下父级宽度为1200px; flex-basis的总和为 1000px,小于父级宽度,将有200px的剩余宽度; 既然有剩余,我们就不要加权计算,剩余的宽度将根据flex-grow,值得总和进行百分比,那么200px就会根据份数比来分配剩余的空间; 剩余后宽度 w = (子元素flex-grow值 /所有子元素flex-grow的总和) * 剩余值 总分数为 total = 1 + 2 + 3; son1的扩展量:(3/total) * 200,即约等于100px; son2的扩展量:(2/total) * 200,即约等于67px; son3的扩展量:(1/total) * 200,即约等于33px; 最后son1、son2、son3,的实际宽度为: 200 + 100 = 300px; 300 + 67 = 367px; 500 + 33 = 533px; 总结 所以以上两种情况下,第二种flex-basis和flex-shrink是不列入计算公式的;第一种flex-grow是不列入计算公式的 ok,上面的两种情况总结完毕,但是很多时候我们的父级是不固定的,那么怎么办,其实很简单了,对照上面的公式,前提是已经设置了flex-basis值得元素,如果宽度的随机值小于flex-basis的时候就按第一种计算,反之第二种;明白了吧。 但是在实际中,我们有些子元素不想进行比例分配,永远是固定的,那么flex就必须设置为none; 否则设置的宽度(width)将无效; flex: 1, 则其计算值为 flex: 1 1 0%; flex: auto, 则其计算值为 flex: 1 1 auto; flex: none, 则其计算值为 flex: 0 0 auto; 根据上面的公式 flex:1的时候第一种方式其实是无效的,因为加权值是0,所以只能是第二种方式计算; flex:none的时候,两种都失效,自己元素不参与父级剩余还是溢出的分配,flex:none的应用场景还是很多的;

    ps:剩下属性就不讲了,大家可以去http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

  • 相关阅读:
    第04组 Beta冲刺(2/4)
    第04组 Beta冲刺(1/4)
    2019 SDN上机第6次作业
    SDN课程阅读作业(2)
    2019 SDN上机第5次作业
    第04组 Alpha事后诸葛亮
    第04组 Alpha冲刺(4/4)
    2019 SDN上机第4次作业
    第04组 Alpha冲刺(3/4)
    第07组 Alpha冲刺(4/6)
  • 原文地址:https://www.cnblogs.com/zwp06/p/9875961.html
Copyright © 2011-2022 走看看