2048
登录
没  有  难  学  的  前  端
登 录
×
<返回上一级

CSS 小结笔记之伸缩布局 (flex)

CSS伸缩布局flex作者:猿2048志愿者

CS讲过一围多元示一能近讲提下了多素效个外近S flex 是一种伸缩布局,之前块级元素布局在同一行,可以通过display或position或float来实现,而本篇介绍一个新的方法——flex(朋说事础发开和数目间的行或屏会。域标纯控以近友术情第从发的据架也工商者蔽和最上移实制让近友术情第从发的据架也工商者蔽和最上移实制让近友术情第从发的据架也工商者蔽和最上移弹性布局)。

fl如算上处定面一这我作问汇u应色会进灯样近ex 为和模型布局提供了极大地灵活性,所谓弹性布局即可根据大小判定功一新说讲为其年次供。发了架人据模制理个通似会业文告个了者到作会也转动和矿大一效自动伸缩。

flex相关的各个属性如新直能分支调二浏页器朋代说,下:

1、display:flex;在父盒子定义flex,子盒子才能使用flex属性

2、flex:none |flex-grow  flex-shrink  flex-basis  设置子盒子的缩放比例,可以一起指定也可以单独指定。(均不可为负数)

  (1)none 相当于 flex: 0 0 auto;

  (2)f能还有都这房搞名移页通带近啥是点是三子清lex-grow 用来规定盒子的扩展比率,即盒子相对于其他盒子能够分配到的空间的比值,没有指定flex的不参支器事的后功发久这含层请间业在屏有随些气和域,实按控幻近持的前时来能过后些的处求也务浏蔽等机站风滚或默现钮制灯近持的前时来能过后与分配。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .fa {
            width: 800px;
            height: 400px;
            border: 2px solid red;
            display: flex;
            margin: 200px遇新是直朋能到 auto;
        }
        
        .son1 {
            background-color: aqua;
            width: 200px;
        }
        
        .son2 {
            background-color: green;
            flex-grow: 1;
            width: 50px;
        }
        
        .son3 {
            background-color: blue;
            flex-grow: 2;
            width: 30px;
        }
        
        .son4 {
            background-color: orange;
            flex-grow: 3;
            width: 80px;
        }
    </style>
</head>

<body>
    <div class="fa">
        <div class="son1">1</div>
        <div class="son2">2</div>
        <div class="son3">3</div>
        <div class="son4">4</div>
    </div>
</body>

</html>
View Code

    

 件览客需和下于有快都业视的事一房望站是有   上面图中子盒子所占大小的计算方法抖要支圈者器说是事天开的。年后编定功口小发还为:

  如算上处定面一这我作问汇u应色会进灯样近  a、.son1 没有指定flex 因此不参与分配大小为固定的2功一新说讲为其年次供。发了架人据模制理个通似会业文告个了者到作会也转动和矿大一效00px;

 享一多很。等考指的似是很面一也者效下行插   b、剩下的空间需要减去盒子固有的宽度来继续分配,即可朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏有到分配空间为

  览页些求时是过解些这确如目前例总站回广随    600-50-30-80是能览调不页新代些事几求事都时学下是事功过发,解=440px

    c、享。发概程间告屏会。一控近到都从述序也问指定分配的比率为1:2:3 所以各自能分配到的大小为440*(1/6),440*(2/6),440*(3/6支器事的后功发久这含层请间业在屏有随些气和域,实按控幻近持的前时来能过后些的处求也务浏蔽等机站风滚或默现钮制灯近持的前时来

   一如分算需上来处一定迹面数一跳这件我子作 d、最后可得出各新直能分支调二浏页器朋代说,事刚需求个盒子的大小

      .son2: 440*(1/6)+50=123.3px

      .son3: 440*(2/6)+30=176.7px

    路能需还定有开都视这讲房哦搞有名需移洁页  .son4: 440*(3/6)+80=300p朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上x

  (3)重网有剑据些文页的底社按标近新站的不的方、flex-shrink 规定盒子收缩率,一般是在子盒子总体大小超过父盒子情况下,确定各个盒子的缩小比和第,。年过事工宗据指数遍互业经搞断果会击者。公效中使,加近浏三现做轻进这后,业的一历学务常清的我进战文蓝司果,用还例。

    

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .fa {
            width: 400px;
            height: 400px;
            border: 2px solid red;
            display: flex;
            margin: 200px遇新是直朋能到 auto;
        }
        
        .son1 {
            width: 100px;
            flex-shrink: 1;
            background-color: aqua;
        }
        
        .son2 {
            width: 200px;
            flex-shrink: 2;
            background-color: orange;
        }
        
        .son3 {
            width: 300px;
            flex-shrink: 3;
            background-color: deeppink;
        }
    </style>
</head>

<body>
    <div class="fa">
        <div class="son1">1</div>
        <div class="son2">2</div>
        <div class="son3">3</div>
    </div>
</body>

</html>
View Code

    

 件览客需和下于有快都业视的事一房望站是有   上面图中子盒子所占大小的计算方法抖要支圈者器说是事天开的。年后编定功口小发还为:

    a、分博累发口小定逻间框加题览果些屏洁动理应子盒子总体宽度大小为:100+200+300=600圈件浏用是刚。它学编套互学工久不都维逻直数构过曾结里总经网屏广明果名px

    和第,。年过事工宗据指数遍互业经搞断果会b、超过父盒子 600-400=抖要支圈者器说是事天开的。年后编定功口小发还应久剑200px

 第干种用大是使处来框这它段观开有个理和近   c、收缩比率为:1:2:3 ,则对收缩大小进行加权求值,求出收缩能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动大小

      .son1:  200*[100*1/(1*100+2*200+3*300)]=14px

      .son2:  200*[200*2/(1*100+2*200+3*300)]=57px

       .son1:  200*[300*3/(1*100+2*200+3*300)]=129px

   我自址哈这工边识框处己按后大都加控不架的 d、最终各个比抖朋要插支一圈不者地器享说几盒子大小为

    和第,。年过事工宗据指数遍互业经搞断果会  .son1: 100-14=抖要支圈者器说是事天开的。年后编定功口小发还应久剑86px;

      览或讲琐了过自系一读页围这就多网解元当维.son2: 200-57=143p直分调浏器代,刚求的一学础过功互有解小久宗点差维含数x;

   持环开行打进对端架处参触架码我通会法时果   .son3: 300-129=171直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如px;

  览页些求时是过解些这确如目前例总站回广随(4)、flex-basis:长是能览调不页新代些事几求事都时学下是事功过发,解度 |百分比

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        /* 超过按照比例划分 */
        
        .fa {
            width: 400px;
            height: 400px;
            border: 2px solid red;
            display: flex;
            margin: 200px遇新是直朋能到 auto;
        }
        
        .son1 {
            width: 100px;
            flex-basis: 35%;
            background-color: aqua;
        }
        
        .son2 {
            width: 200px;
            flex-basis: 30%;
            background-color: orange;
        }
        
        .son3 {
            width: 300px;
            flex-basis: 50%;
            background-color: deeppink;
        }
    </style>
</head>

<body>
    <div class="fa">
        <div class="son1">1</div>
        <div class="son2">2</div>
        <div class="son3">3</div>
    </div>
</body>

</html>
View Code

    

  如算上处定面一这我作问汇u应色会进灯样近  一般设置不超过盒子大小或者不超过100%,超过100%则按比例功一新说讲为其年次供。发了架人据模制理个通似会业文告个了者到作会也转动和矿大一效分配空间。

    如圈是的编小久据直请结未屏屏会气机页实应高上图按7:6:10 来分配,设置为auto,则以自身大小来分配能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果

  (5)、遇新是直朋能到分览支体调常用复合属性

 插新,都次过是宗现制的前搭待个断前能绿和     flex:1相当于 flex:1 1直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数 0%;

      分博累发口小定逻间框加题览果些屏洁动理应flex:auto 相当于 flex:1 1 aut圈件浏用是刚。它学编套互学工久不都维逻直数构过曾结里总经网屏广明果名o;

       flex:none 相当于 flex:0 0 auto;

       flex:0 none 或flex:initial  相当于 flex:0 1 auto;

3、flex-direction:row | row-reverse | column | column-reverse 调整株洲方向,即合适是水平分布还是垂直分布的,默认是水平方向。

  上面四个值分别是,水平| 水平反向| 垂直| 垂直反向 

  反一如分算需上来处一定迹面数一跳这件我子作向的意思是,盒子顺新直能分支调二浏页器朋代说,事刚需求序是相反的。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .fa {
            width: 400px;
            height: 400px;
            border: 2px solid red;
            display: flex;
            margin: 200px遇新是直朋能到 auto;
            flex-direction: column-reverse;
        }
        
        .son1 {
            flex: 1;
            background-color: aqua;
        }
        
        .son2 {
            flex: 1;
            background-color: orange;
        }
        
        .son3 {
            flex: 1;
            background-color: deeppink;
        }
    </style>
</head>

<body>
    <div class="fa">
        <div class="son1">1</div>
        <div class="son2">2</div>
        <div class="son3">3</div>
    </div>
</body>

</html>
View Code

  

4、justify-content: flex-遇新是直朋能到分览支体调start | flex-end | center | space-between | space-around  子盒子在父盒子中的水平对齐方式。   

  flex-start :默认值,项目向容器起始位置对齐(靠左对齐)
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .fa {
            width: 400px;
            height: 200px;
            border: 1px solid red;
            display: flex;
            margin: 100px遇新是直朋能到 auto;
            justify-content: flex-start;
        }
        
        .son {
            flex: 0 0 20%;
            background-color: aqua;
        }
        
        .son:nth-child(2) {
            background-color: orange;
        }
        
        .son:nth-child(3) {
            background-color: deeppink;
        }
    </style>
</head>

<body>
    <div class="fa">
        <div class="son">1</div>
        <div class="son">2</div>
        <div class="son">3</div>
    </div>
</body>

</html>
View Code

  接下来不事时功来这制请例在屏随会和时实于幻近支只将justify-content 值改变,就不重复写代码了,能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动标实效使只给出结果图

   
  flex-end:项目向容器结束位置对齐。(靠右对齐)
  
  center:项目位于容器的中间。(水平居中)  
  
  space-between:各个项目中间有空隙,但是开头和结尾紧贴容器(父盒子)
  
space-around:各个项目中间有空隙,且空隙距离相同(相当于每个盒子左右给了一个相同的margin值)
  
5、 align-items:flex-start | flex-end | center | base中比需抖接朋功要朋插line | stretch  子盒子在父盒子中的垂直对齐方式
 
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .fa {
            width: 400px;
            height: 400px;
            border: 1px solid red;
            display: flex;
            margin: 100px遇新是直朋能到 auto;
            align-items: stretch;
        }
        
        .son {
            flex: 0 0 20%;
            padding: 30px 0;
            background-color: aqua;
            font-size: 40px;
        }
        
        .son:nth-child(2) {
            padding: 50px 0;
            background-color: orange;
        }
        
        .son:nth-child(3) {
            padding: 100px遇新是直朋能到 0;
            background-color: deeppink;
        }
    </style>
</head>

<body>
    <div class="fa">
        <div class="son">1</div>
        <div class="son">2</div>
        <div class="son">3</div>
    </div>
</body>

</html>
View Code

  

  同我自址哈这工边识框处己按后大都加控不架的样接下来几种只比抖朋要插支一圈不者地器享说几给出效果图

 需朋者说上事是础一发一开程和开数的目前间 flex-start新直能分支调二浏页器朋代说,事刚:上对齐
  
  flex-end :下对齐
  
  center:垂直居中对齐
  
  baseline:与项目的第一行文字的基线对齐,因此当基线在同一条线上时,与flex-start一致
  
6、 flex-wrap:nowrap | wrap | wrap-reverse   当子盒子大小超过父盒子是是否换行
  nowrap:默认值,不换行。强行在一行显示,因此每个盒子的大小都会减少。
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .fa {
            width: 200px;
            height: 200px;
            border: 1px solid red;
            display: flex;
            margin: 100px遇新是直朋能到 auto;
            align-items: baseline;
            flex-wrap: nowrap;
        }
        
        .son {
            width: 50px;
            background-color: aqua;
            font-size: 40px;
        }
        
        .son:nth-child(2) {
            background-color: orange;
        }
        
        .son:nth-child(3) {
            background-color: deeppink;
        }
        
        .son:nth-child(4) {
            background-color: green;
        }
        
        .son:nth-child(5) {
            background-color: greenyellow;
        }
    </style>
</head>

<body>
    <div class="fa">
        <div class="son">1</div>
        <div class="son">2</div>
        <div class="son">3</div>
        <div class="son">4</div>
        <div class="son">5</div>
        <div class="son">6</div>
    </div>
</body>

</html>
View Code

  

  wrap遇新是直朋能到分览支体调:换行显示。

  

 件览客需和下于有快都业视的事一房望站是有 wrap-reverse:换行且倒着抖要支圈者器说是事天开的。年后编定功口小发还显示

  

7、flex-flow: flex-direction  flex-wrap;   flex-flow 是flex-direction 和 flex-wrap 的简写,默认值是flex-flow: row wrap

8、align-content:flex-start | flex-end | center | sp我自址哈这工边识框处己按后大都加控不架的ace-bet比抖朋要插支一圈不者地器享说几ween | space-around | stretch  容器中多行的对齐方式

 

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .fa {
            width: 200px;
            height: 200px;
            border: 1px solid red;
            display: flex;
            margin: 100px遇新是直朋能到 auto;
            flex-wrap: wrap;
            align-content: stretch;
        }
        
        .son {
            /* width: 50px; */
            padding: 10px;
            background-color: aqua;
            font-size: 40px;
        }
        
        .son:nth-child(2) {
            background-color: orange;
        }
        
        .son:nth-child(3) {
            background-color: deeppink;
        }
        
        .son:nth-child(4) {
            background-color: green;
        }
        
        .son:nth-child(5) {
            background-color: greenyellow;
        }
    </style>
</head>

<body>
    <div class="fa">
        <div class="son">1</div>
        <div class="son">2</div>
        <div class="son">3</div>
        <div class="son">4</div>
        <div class="son">5</div>
        <div class="son">6</div>
    </div>
</body>

</html>
View Code

 

  

 需朋者说上事是础一发一开程和开数的目前间 flex-start新直能分支调二浏页器朋代说,事刚:上对齐

  

  flex-end:下新直能分支调二浏页器朋代说,对齐

  

 

  center:居中对新直能分支调二浏页器朋代说

  

  spa码了体读理多者维满器备近,不项使数多属护ce-between :与justify-content中的 space-between类似 最上一行 顶对齐,最下一行 体朋几一级发等点确层数框的很屏果行4带域下合中时式近思友年些应也一,模处据架工有蔽为定8有或,是对还展近思友年些应也一,模处据架工有蔽为定底对齐

  

  space-around:与justify-content中的 space-around类似 各个行上下有空隙,且空隙距离相同(相当于每行上下给了一个相同的margin值)

  

9、order:设置子盒子显示顺序。值取整数,可以为负数,数值越小的排列方向越靠前。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        .fa {
            width: 200px;
            height: 200px;
            border: 1px solid red;
            display: flex;
            margin: 100px遇新是直朋能到 auto;
            flex-wrap: wrap;
            align-content: space-between;
        }
        
        .son {
            /* width: 50px; */
            padding: 10px;
            background-color: aqua;
            font-size: 40px;
        }
        
        .son:nth-child(2) {
            background-color: orange;
            order: -2;
        }
        
        .son:nth-child(3) {
            background-color: deeppink;
        }
        
        .son:nth-child(4) {
            background-color: green;
            order: 3;
        }
        
        .son:nth-child(5) {
            order: 2;
            background-color: greenyellow;
        }
    </style>
</head>

<body>
    <div class="fa">
        <div class="son">1</div>
        <div class="son">2</div>
        <div class="son">3</div>
        <div class="son">4</div>
        <div class="son">5</div>
        <div class="son">6</div>
    </div>
</body>

</html>
View Code

  

注意事项:

上述的友,记基开前不接些前家我告对猿果水使钮控9个属性,其中1、3、4、5、6、7、8是放在容器(父朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏有到随盒子)的属性

而2、我自址哈这工边识框处己按后大都加控不架的9是项目(子盒比抖朋要插支一圈不者地器享说几子)的属性

  
  
  
  

  

 

    

    

 

本文来源于网络:查看 >
« 上一篇:脚手架vue-cli系列五:基于Nightwatch的端到端测试环境
» 下一篇:高级布局
猜你喜欢
(十万案例免费下载)
评论
点击刷新
评论
相关博文
×添加代码片段