CSS三大定位方式(浮动、定位、弹性盒)详细解析

news2024/10/6 6:41:19

CSS三大定位方式

前言:作为一名前端开发,已经工作2年了。由于自己是半路出家,从嵌入式方向转到前端开发,都是边百度边开发,很多基础都不了解,只要解决问题就好,但是近来为了让自己知识体系化,也是为了让自己走的更远,所以写此文来系统学习一下css中的三大定位方式(浮动、定位、弹性盒)。

一,浮动布局

1.没有设置浮动的块元素是独占一行的

    <style>
        div{
            width: 100px;
            height: 100px;
            border: 1px solid red;
        }
        div:nth-child(1){
            background-color: #79bbff;
        }
        div:nth-child(2){
            background-color: #95d475;
        }
    </style>
	 <body>
	    <div></div>
	    <div></div>
	</body>

在这里插入图片描述

2.浮动是对后面元素的影响,对第二个元素设置浮动对第一个元素没有影响,和上图一样,

    <style>
        div:nth-child(1){
            background-color: #79bbff;
        }
        div:nth-child(2){
            float: left; 
            background-color: #95d475;
        }
    </style>

但是如果对一个元素设置浮动,后面的元素就会占用第一个元素的空间位

    <style>
        div:nth-child(1){
            float: left;
            background-color: #79bbff;
        }
        div:nth-child(2){
            background-color: #95d475;
        }
    </style>

在这里插入图片描述
你可能会有疑问,为什么看到的还是第一个元素啊?
这是因为:
浮动元素会从文档流中脱离,但它的背景色仍然会填充在其原本的位置上,而不受其他元素的影响。所以,虽然第一个元素被第二个元素覆盖,但是它的背景色仍然会显示出来。

我们去掉第一个元素的背景就可以直观的看到效果

    <style>
        div:nth-child(1){
            float: left;
        }
        div:nth-child(2){
            background-color: #95d475;
        }
    </style>

在这里插入图片描述

3.两个元素都设置浮动后,会并排显示。

    <style>
        div:nth-child(1){
            float: left;
      
        }
        div:nth-child(2){
            float: left;
            background-color: #95d475;
        }
    </style>
<body>
    <div></div>
    <div></div>
</body>

在这里插入图片描述
这是因为浮动元素会脱离正常的文档流,并尝试尽可能向左或向右浮动,直到它们碰到容器的边界或者其他浮动元素为止。

4.浮动元素边界是父元素的padding,如果给上面的代码body加一个padding:100px;

     body{
            padding:100px;
        }

在这里插入图片描述
可以看到元素在padding处就无法继续往左边靠拢了。

5.在 CSS 中,任何元素都可以浮动。浮动元素会生成一个块级。

    <style>
        span{
            border: 2px solid green;
            width: 100px;
            height: 100px;
        }
    </style>
    <span>A股市场,外星人来了,都必须把船留下!</span>

在这里插入图片描述
可以发现我们对一个行级元素是无法设置宽度和高度的,但是如果设置其为块级元素就可以了。

        span{
            display: block;
            border: 2px solid green;
            width: 100px;
            height: 100px;
        }

或者设置元素浮动,系统会自动将浮动的元素置为块级元素

        span{
            float:left;
            border: 2px solid green;
            width: 100px;
            height: 100px;
        }

在这里插入图片描述

6.clear 可以清除浮动;left 左边远离浮动元素;right left 右边远离浮动元素;both 左右都远离浮动元素


二,定位布局

定位的基本思想很简单,也就是相对于定位的元素的参考系不同而分为三种情况

  1. 相对于其正常位置应该出现的位置
  2. 相对于父元素、另一个元素
  3. 相对于浏览器窗口本身的位置

定位类型分为五种情况

  1. static : 默认形为,就是文档流从上到下,从左往右
  2. relative :相对定位 (会保留原有的空间位,下文详细讨论)
  3. absolute :绝对定位 (如果父元素有定位属性,参照父元素定位,会一直往上找,直到找到为止 ,下文详细讨论)
  4. fixed :固定定位 (相对于页面的定位)
  5. sticky :粘性定位 (有元素溢出滚动时有效)

1.先简单体会一下什么是定位,以及基本用法

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body {
            padding: 50px;
        }

        main {
            width: 300px;
            height: 200px;
            border: solid 6px blueviolet;
            margin: 20px;
        }

        div {
            font-size: 25px;
            background: #f2a67d;
            padding: 10px;
            position: absolute;
            top: 0;
            left:500px;
            bottom: 700px;
            right:50%;
        }
    </style>
</head>
    <body>
        <main>
            <div>本应该出现在main里面的</div>
        </main>
    </body>
</html>

在这里插入图片描述
可以发现本来应该出现在边框里面的div通过绝对定位出现在了边框的外面,此时我们css中的 top: 0; left:500px; bottom: 700px; right:50%;分别代表元素距离浏览器的上边框,左边,下边,右边的距离,为0 代表紧靠上边框。
还记得上面我们说过

  1. absolute :绝对定位 (如果父元素有定位属性,参照父元素定位,会一直往上找,知道找到为止 ,下文详细讨论)

当前是因为当前父元素没有定位属性,一直找到了根节点,都没有当前div的“祖先”,所以就参考根节点的位置来定位。

如果我们给div的父元素main随便来一个定位属性(为了方便观看,我也修改了定位值)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body {
            padding: 50px;
        }

        main {
            width: 300px;
            height: 200px;
            border: solid 6px blueviolet;
            margin: 20px;
            position: relative;
        }

        div {
            font-size: 25px;
            background: #f2a67d;
            padding: 10px;
            position: absolute;
            top: 0;
            left:10px;
            bottom: 10px;
            right:50%;
        }
    </style>
</head>
    <body>
        <main>
            <div>本应该出现在main里面的</div>
        </main>
    </body>
</html>

我们对照设置的位置 top: 0; left:10px; bottom: 10px; right:50%;看效果 是不是如果父元素有定位属性,那么我们的元素定位也就以父元素为参考系来定位?
在这里插入图片描述

2.接下来我们讨论相对定位

相对定位是相对于元素原来的位置控制,当元素发生位置偏移时,原位置留白。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
    article{
        width: 200px;
        height: 200px;
        border: 1px solid #000;
        
    }
    article div{
        display: inline-block;
        width: 50px;
        height: 50px;
        background-color: blue;
    }
</style>
<body>
    <article>
        <div></div>
        一个人用100元买了50双拖鞋,拿到地摊上每双卖3元,一共得到了150元。另一个人很穷,每个月领取100元生活补贴,
        全部用来买大米和油盐。同样是100元,前一个100元通过经营增值了,成为资本。后一个100元在价值上没有任何改变,只不过是一笔生活费用
    </article>
</body>
</html>

在这里插入图片描述
现在我们对div设置浮动,让它向上移动,把位置让给文字,

    article div{
        display: inline-block;
        width: 50px;
        height: 50px;
        background-color: blue;
        position: relative;
        top: -40px;
    }

看效果:
在这里插入图片描述

我们可以发现原位置还在保留。但如果position: relative;换成 position:absolute;或者fixed那么位置就不会保留了。
这里我们不妨认为相对定位relative 是一个对爱情专一的男孩,即使你走了很久很久…relative的心里还留有你的位置。----相对定位是相对于元素原来的位置控制,当元素发生位置偏移时,原位置留白。

3.接下来我们讨论绝对定位

绝对定义不受文档流的影响,还记得我们在体验定位的那个例子么?如果父元素有定位属性,参照父元素定位
绝对定位可以设置元素尺寸,虽然没有强调 ,还是那个例子其实你应该已经体会到了;
我们通过设置距离父元素左右两侧的位置,可以改变元素的大小,在此就不在赘述了。
相应的通过 将 left 设置为 50% ,并向左偏移子元素宽度一半可以实现水平居中,这些都是绝对定位的应用场景。
因为绝对定位的参考系是父元素(如果没有,也就相当于元素以根节点为父元素),那么当我们滚动的时候,各位想一下我们的绝对定位元素是否会跟着滚动呢?

上代码看结果:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
  body {
    padding: 50px;
  }
  main {
    width: 300px;
    height: 200px;
    border: solid 10px blueviolet;
    position: relative;
    overflow: scroll;
  }
  main article {
    height: 600px;
  }
  main article div {
    width: 200px;
    height: 200px;
    position: absolute;
    background: red;
    left: 250px;
    bottom: 0px;
    z-index: 2;
  }

</style>
<body>
    <main>
        <article>
            <div></div>
        </article>
    </main>
</body>
</html>

在这里插入图片描述
这里绝对定位元素虽然也会动,但是各位一定要想明白,滚动只是为了展示内容,其实绝对定位的元素相对于父元素是没有变化的,就像你坐汽车,看窗外的小姐姐,在飞速的移动是一个道理,不是小姐姐在动,是你的车在动,小姐姐并没有移动,因为被绝对定位absolute拿绳子捆住了,她无法移动。

4.接下来我们讨论固定定位

当你整明白绝对定位,那么固定定位一句话就搞定了,
固定定位的参考系永远都是可视页面
上代码看效果

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
  body {
    padding: 50px;
    overflow: auto;
    height: 2000px;
  }
  main {
    width: 300px;
    height: 200px;
    border: solid 10px blueviolet;
    overflow: auto;
  }
  main article {
    height: 600px;
  }
  main article div {
    width: 200px;
    height: 200px;
    position: fixed;
    background: red;
    left: 100px;
    bottom:-100px;
    z-index: 2;
  }

</style>
<body>
    <main>
        <article>
            <div></div>
        </article>
    </main>
</body>
</html>

在这里插入图片描述

5.接下来我们讨论粘性定位

粘性定位是相对定位relative和固定定位fixed的结合;它主要用在对scroll事件的监听上;
简单来说,在滑动过程中,某个元素距离其父元素的距离达到sticky粘性定位的要求时(比如top:100px);position:sticky这时的效果相当于fixed定位,固定到适当位置。

整明白粘性定位记住2句话即可
1.粘性定位只是在有溢出滚动时有效,配合top,bottom ,left ,right 属性使用
2.设置粘性定位的元素,同级时叠加效果,不同级是顶走的效果

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
  * {
    padding: 0;
    margin: 0;
  }
  main {
    padding: 30px;
  }
  main article {
    width: 400px;
    height: 200px;
    border: solid 5px red;
    overflow: scroll;
  }
  main article h2 {
    background: #db1f77;
    color: white;
    text-indent: 20px;
    position: sticky;
    top: 20px;
  }
  main article h2:nth-of-type(1) {
    background: blue;
  }
  main article div {
    height: 200px;
  }
</style>
<body>
  <main>
      <article>
   
          <h2>今年还有4次调休</h2>
          <div>
            今年清明节4月4日至6日放假调休,共3天。4月7日(星期日)上班。
            今年劳动节5月1日至5日放假调休,共5天。4月28日(星期日)、5月11日(星期六)上班。
            今年端午节在6月10日放假1天,与周末连休。
            今年中秋节于9月15日至17日放假调休,共3天。9月14日(星期六)上班。
            今年国庆节10月1日至7日放假调休,共7天。9月29日(星期日)、10月12日(星期六)上班。(中国政府网,希隆)
          </div>
          <h2>女子被丈夫怒抛高速</h2>
          <div>
            近日,湖南长沙,一女子报警求助称被困高速公路。原因竟是其同丈夫二人趁春节自驾出去游玩,途中丈夫驾车需要导航,女子因输错了一个字,
            导致路线偏离,气头上的丈夫便将妻子赶下了车。民警随后联系上了女子丈夫,严厉批评教育后责令其将女子从安全地点接回。民警:成年人请管理好自己的情绪!(湖南都市1时间)
          </div>

      </article>
  </main>
</body>
</html>


在这里插入图片描述
看效果可以发现,当我们对article h2设置top:20px ;position: sticky;后其位置 固定在相对于父节点位置相差20px,当有新的粘性元素来的时候会覆盖之前的粘性元素也就是叠加效果

看下面这个代码覆盖效果更明显

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>


.container > div {
    height: 50vh;
    margin-bottom: 20px;
}
.container > div {
    position: sticky;
    top: 0;
}

</style>
<body>

  <div class="container">
    <div style="background: #655;width: 100%;">1</div>
    <div style="background: #FFD700;width: 90%;">2</div>
    <div style="background: #58a;width: 80%;">3</div>
    <div style="background: #A9C931;width: 70%;">4</div>
</div>


</body>
</html>


在这里插入图片描述

以上2个覆盖效果都是建立在粘性元素是同级的前提下,接下来看一下不是同级是什么情况

在这里插入图片描述
只是在第一个例子加一层div
看效果:
在这里插入图片描述
我们不妨这样理解:
固定在相对于父节点位置的粘性定位元素被父元素带走了,后面元素紧随其后,最终呈现效果就是一个推着一个走。

三,弹性盒布局

Flex 是 Flexible Box 的缩写,翻译为灵活的盒子 或为"弹性布局",简单方便快速是它的特点,能用弹性模型布局我推荐大家就用弹性盒模型,当然使用浮动或者定位也没错,这个就像现在新能源汽车一样,混动就是要比传统汽油车有更多的优势,放着性价比更高的吉利比亚迪不买,你非要买卡罗拉是一个道理。要面子没面子 ,要安全不安全,蓝牌还限号,只能说没错,但是不推荐了。

1.弹性盒声明,及排列方式

要想使用弹性盒,首先需要有‘盒子’;然后其内的元素才会按照一定的规则布局,那么声明弹性盒主要有2种方式:
1.块级盒子: display:flex;
2,行级盒子: display:inline-flex;

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>

</style>
<body>

  <div>拉面</div>
  <div>扯面</div>
  <div>刀削面</div>
  <div>油泼面</div>

</body>
</html>

在这里插入图片描述
div是块级元素,所以每一个div会占用一行,但是当我们声明body为弹性盒以后,发现排列方式变化了,这也就说明弹性盒生效了

在这里插入图片描述

在这里插入图片描述
这是因为弹性盒排列方式flex-direction 默认是row排列。
如果修改flex-direction: column;那么就是纵向排列,效果如下:
在这里插入图片描述

如果修改flex-direction: column-reverse;那么就是纵向反转排列效果如下:
在这里插入图片描述

2.弹性盒元素溢出时处理方式

当弹性盒内元素过多,放不下时候,分为2种先处理:
1.元素缩小,挤进去
2.元素大小不表,换行

元素自动缩小挤进去是默认行为
举例代码:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>

  #app{
    display: flex;
    width: 900px;
    border: 6px solid red;
  }
  #app div{
    width: 100px;
    height: 100px;
    border: 1px solid #000;
    margin: 10px;
    }
</style>
<body>

  <div id="app">
      <div>1</div>
      <div>2</div>
      <div>3</div>
      <div>4</div>
  </div>

</body>
</html>

可以放下一切正常的效果:
在这里插入图片描述

如果设置#app的宽度小于四个div宽度的时候:

  #app{
    display: flex;
    width: 300px;//缩小宽度
    border: 6px solid red;
  }

看效果:
在这里插入图片描述
那么如果让元素保持原尺寸 换行呢?
只需要增加一个属性:flex-wrap: wrap;

  #app{
    display: flex;
    width: 300px;
    border: 6px solid red;
    flex-wrap: wrap;
  }

看效果:
在这里插入图片描述
当然和上面介绍的反向排列方式一样,这里也有反向换行这个概念,这里不在赘述 flex-wrap: wrap-reverse;

小总结:
设置排列方式:flex-direction: row;
设置是否换行 :flex-wrap: wrap;
可以缩写成一个属性: flex-flow: row wrap; 最终效果是一样的

3.区分好弹性盒的主轴和交叉轴(副轴)

主轴和副轴是相互垂直的2条有方向的直线
要想区分主轴和副轴,前提是知道弹性盒排列方式(flex-direction)是横向还是纵向,是正向还是反向
举例说明:
1.下面是使用 flex-flow: row wrap 的主轴与交叉轴说明:
在这里插入图片描述
2.下面是使用 flex-flow: row-reverse wrap-reverse 的主轴与交叉轴说明:

在这里插入图片描述
3.下面是使用 flex-flow: column wrap 的主轴与交叉轴说明。
在这里插入图片描述

4.控制元素在主轴上的排列方式。justify-content

选项说明
flex-start元素紧靠主轴起点
flex-end元素紧靠主轴终点
center元素从弹性盒元素中心开始
space-between第一个元素靠起点,最后一个元素靠终点,余下元素平均分配空间(左右靠边, 中间平均
space-around每个元素两侧的间隔相等。所以,元素之间的间隔比元素与容器的边距的间隔大一倍
space-evenly元素间距离完全平均分配
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>

  #app{
    display: flex;
    width: 900px;
    border: 6px solid red;
    justify-content: flex-start;
  }
  #app div{
    width: 100px;
    height: 100px;
    border: 1px solid #000;
    margin: 10px;
    }
</style>
<body>

  <div id="app">
      <div>1</div>
      <div>2</div>
      <div>3</div>
      <div>4</div>
  </div>

</body>
</html>

仅改变justify-content的值我们来看效果

justify-content: flex-start:
在这里插入图片描述
justify-content: flex-end:
在这里插入图片描述
justify-content: center:
在这里插入图片描述
justify-content:space-between:
在这里插入图片描述
justify-content:space-around:
在这里插入图片描述
justify-content:space-evenly:
在这里插入图片描述

5.控制元素在交叉轴上的排列方式。align-items

选项说明
stretch默认值,如果弹性子元素没有高度或高度为auto,将占满整个容器的高度
center元素位于容器的中心
flex-start元素位于容器的交叉轴开头
flex-end元素位于容器的交叉轴结尾
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>

  #app{
    display: flex;
    width: 900px;
    height: 300px;
    border: 6px solid red;
    justify-content:flex-start;
    align-items:stretch;
  }
  #app div{
    width: 100px;
    /* height:100px; */
    border: 1px solid #000;
    margin: 10px;
    }
</style>
<body>

  <div id="app">
      <div>1</div>
      <div>2</div>
      <div>3</div>
      <div>4</div>
  </div>

</body>
</html>

align-items:stretch:

仅改变align-items,(去掉div的高度)我们来看效果
在这里插入图片描述
center,flex-start,flex-end和主轴效果类似,不在赘述

6.有多行时,控制对齐方式

前提是弹性盒有高度,换行导致的·高度无效
适用于多行显示的弹性容器,用于控制行(而不是元素)在交叉轴上的排列方式。
属性是align-content,属性值和 justify-content (用于控制元素在主轴上的排列方式)一模一样
切记aligin-content,有1个前提和1个受控者
前提是:弹性盒须有高度,受控者切记是元素所在行,而不是元素本身

7.对单个元素交叉轴进行设置

align-self 用于控制单个元素弹性元素的交叉轴排列

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>


  article {
    width: 400px;
    height: 400px;
    border: solid 5px red;
    display: flex;
    justify-content: center;
  }
  article div {
    height: 50px;
    width: 50px;
    border: solid 5px blueviolet;
  }
  article div:nth-of-type(2) {
    align-self: center;
  }
  article div:nth-of-type(3) {
    align-self: flex-end;
  }

</style>
<body>

  <article>
    <div>1</div>
    <div>2</div>
    <div>3</div>
</article>

</body>
</html>

在这里插入图片描述

8.flex-grow决定了元素如何扩展拉伸

先看代码和效果,根据效果分析

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>

  #app{
    display: flex;
    width: 900px;
    border: 6px solid red;

  }
  #app div{
    width: 100px;
    height:100px;
    border: 1px solid #000;
    margin: 10px;
    }
    #app div:nth-child(1){
      flex-grow: 0;
    }
    #app div:nth-child(2){
      flex-grow: 1;
    }
    #app div:nth-child(3){
      flex-grow: 2;
    }
    #app div:nth-child(4){
      flex-grow: 3;
    }
</style>
<body>

  <div id="app">
      <div>1</div>
      <div>2</div>
      <div>3</div>
      <div>4</div>
  </div>

</body>
</html>

在这里插入图片描述

首先,flex-grow是设置在弹性元素身上的,flex-grow为0标识保持原来大小
效果中第一个div设置flex-grow为0 ;其余依次设置flex-grow为1,2,3 ;
表示第一个元素宽度保持不边,剩下的宽度分为1+2+3 =6 份;第二个div占六分之一,第三个div占六分之二,第四个div占六分之三。

9. flex-shrinkl决定了元素如何收缩

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<style>

  #app{
    display: flex;
    width: 200px;
    border: 6px solid red;

  }
  #app div{
    width: 100px;
    height:100px;
    border: 1px solid #000;
    }
    #app div:nth-child(1){
      flex-shrink: 0;
    }
    #app div:nth-child(2){
      flex-shrink: 1;
    }
    #app div:nth-child(3){
      flex-shrink: 2;
    }
    #app div:nth-child(4){
      flex-shrink: 3;
    }
    
</style>
<body>

  <div id="app">
      <div>1</div>
      <div>2</div>
      <div>3</div>
      <div>4</div>
  </div>

</body>
</html>

在这里插入图片描述
这个缩小和上面描述的flex-grow 原理一样,放大时候,放大比例越高,占空间越大,缩小时候相反,缩小比例越高,占用空间越小

10.flex属性

flex 是 flex-grow、flex-shrink 、flex-basis 缩写组合。
上文我们介绍了grow和shrink的区别和用法,现在说明一下basis的用法:

flex-basis 实际上决定了一个 flex 项目在主轴方向上的初始大小。如果 flex-basis 的值为 auto,那么项目的大小将是其内容的大小。如果 flex-basis 设置了具体的值,如 100px,那么无论内容的大小,项目的初始大小都将是 100px。
然后,flex-grow 和 flex-shrink 将决定项目如何分配剩余的空间(如果有的话)或者如何在空间不足时进行缩小。

<!DOCTYPE html>
<html>
<head>
<style>
.container {
  display: flex;
  width: 500px;
}

.item1 {
  flex: 1 1 200px;
  background-color: lightblue;
}

.item2 {
  flex: 1 1 50px;
  background-color: lightpink;
}
</style>
</head>
<body>

<div class="container">
  <div class="item1">1</div>
  <div class="item2">2</div>
</div>

</body>
</html>

在这里插入图片描述

container宽度为500px;item1的基础宽度为200px,item2的基础宽度为50px,那么剩下500-200-50=250px的宽度可以用来拓展,
由于设置了 flex: 1 1 200px; flex: 1 1 50px; 其中第一个1代表flex-grow平均分配剩余空间,所以
item1的最终宽度为:基础的200px+剩余空间平均分配(250/2 = 125) = 325px;

还有一个属性是order:
order可以改变弹性元素的顺序,数字越大越靠后
如果想让上图中的红色显示在前面那么只需要给item增加order即可

.item1 {
  flex: 1 1 200px;
  background-color: lightblue;
  order: 99;
}

在这里插入图片描述

  • 注意:flex:1;这种缩写表代表 同时设置了 flex-grow: 1、flex-shrink: 1、flex-basis: 0
    这三个属性 让所有弹性盒模型对象的子元素都有相同的长度,且忽略它们内部的内容; flex-basis:
    0和auto是有差别的;auto表示是尊重内容的大小,而0表示忽略
    如果Flex容器有剩余空间,该项目会等比例放大占据剩余空间;如果Flex容器空间不足,该项目会等比例缩小。

四,总结

以上就是css中的三大定位方式和他们的基本用法,欢迎大家批评指正!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1468986.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【数据结构(顺序表)】

一、什么是数据结构? 数据结构是由“数据”和“结构”两词组合而来。 什么是数据&#xff1f;常见的数值1、2、3、4.....、教务系统里保存的用户信息&#xff08;姓名、性别、年龄、学历等等&#xff09;、网页里肉眼可以看到的信息&#xff08;文字、图片、视频等等&#xff…

Yolo v9 “Silence”模块结构及作用!

论文链接&#xff1a;&#x1f47f; YOLOv9: Learning What You Want to Learn Using Programmable Gradient Information 代码链接&#xff1a;&#x1f47f; https://github.com/WongKinYiu/yolov9/tree/main Silence代码 class Silence(nn.Module):def __init__(self):supe…

Mysql运维篇(四) MHA

大佬博文 https://www.cnblogs.com/gomysql/p/3675429.html MySQL 高可用&#xff08;MHA&#xff09; - 知乎 一、MHA简介&#xff1a; MHA&#xff08;Master High Availability&#xff09;目前在MySQL高可用方面是一个相对成熟的解决方案&#xff0c;它由日本DeNA公司y…

【Linux进程】进程状态---进程僵尸与孤儿

&#x1f4d9; 作者简介 &#xff1a;RO-BERRY &#x1f4d7; 学习方向&#xff1a;致力于C、C、数据结构、TCP/IP、数据库等等一系列知识 &#x1f4d2; 日后方向 : 偏向于CPP开发以及大数据方向&#xff0c;欢迎各位关注&#xff0c;谢谢各位的支持 目录 1.进程排队2.进程状态…

uni-app nvue vue3 setup中实现加载webview,解决nvue中获取不到webview实例的问题

注意下面的方法只能在app端使用&#xff0c; let wv plus.webview.create("","custom-webview",{plusrequire:"none", uni-app: none, width: 300,height:400,top:uni.getSystemInfoSync().statusBarHeight44 }) wv.loadURL("https://ww…

Sentinel微服务流量治理组件实战上

目录 分布式系统遇到的问题 解决方案 Sentinel 是什么&#xff1f; Sentinel 工作原理 Sentinel 功能和设计理念 流量控制 熔断降级 Sentinel工作主流程 Sentinel快速开始 Sentinel资源保护的方式 基于API实现 SentinelResource注解实现 Spring Cloud Alibaba整合…

《隐私计算简易速速上手小册》第7章:隐私计算与云计算/边缘计算(2024 最新版)

文章目录 7.1 云计算中的隐私保护7.1.1 基础知识7.1.2 主要案例:使用 Python 实现云数据的安全上传和访问7.1.3 拓展案例 1:实现基于角色的访问控制7.1.4 拓展案例 2:使用 Python 保护 API 安全7.2 边缘计算的隐私问题7.2.1 基础知识7.2.2 主要案例:使用 Python 实现边缘设…

halcon中的一维测量

一维测量 像点到点的距离&#xff0c;边缘对的距离等沿着一维方向的测量都属于1D测量范畴。Halocn的一维测量首先构建矩形或者扇形的ROI测量对象&#xff0c;然后在ROI内画出等距离的、长度与ROI宽度一致的、垂直于ROI的轮廓线&#xff08;profile line&#xff09;的等距线。…

Jenkins解决Host key verification failed (2)

Jenkins解决Host key verification failed 分析原因情况 一、用OpenSSH的人都知ssh会把你每个你访问过计算机的公钥(public key)都记录在~/.ssh/known_hosts。当下次访问相同计算机时&#xff0c;OpenSSH会核对公钥。如果公钥不同&#xff0c;OpenSSH会发出警告&#xff0c;避免…

Java 学习和实践笔记(20):static的含义和使用

static的本义是静止的。在计算机里就表示静态变量。 在Java中&#xff0c;从内存分析图上可以看到&#xff0c;它与类、常量池放在一个区里&#xff1a; 从图可以看到&#xff0c;普通的方法和对象属性&#xff0c;都在heep里&#xff0c;而static则在方法区里。 static声明的…

Linux第65步_学习“Makefie”

学习“Makefie”&#xff0c;为后期学习linux驱动开发做铺垫。 1、在“/home/zgq/linux/atk-mp1”创建一个“Test_MakeFile”目录用于学习“Makefie”。 打开终端 输入“cd /home/zgq/linux/回车”&#xff0c;切换到“/home/zgq/linux/”目录 输入“mkdir Linux_Drivers回…

【AUTOSAR】--02 AUTOSAR网络管理相关参数

这是AUTOSAR网络管理梳理的第二篇文章&#xff0c;主要讲解AUTOSAR网络管理的相关参数。第一篇链接【01 AUTOSAR网络管理基础】。​ 相关参数有很多&#xff0c;我挑了一些相对重要的参数&#xff0c;分三部分进行讲解&#xff1a; 第一部分&#xff1a;比较常用&#xff0c…

uni-app 实现拍照后给照片加水印功能

遇到个需求需要实现&#xff0c;研究了一下后写了个demo 本质上就是把拍完照后的照片放到canvas里&#xff0c;然后加上水印样式然后再重新生成一张图片 代码如下&#xff0c;看注释即可~使用的话记得还是得优化下代码 <template><view class"content"&g…

​Sqli-labs靶场第9关详解[Sqli-labs-less-9]

Sqli-labs-Less-9 前言&#xff1a; SQL注入的三个条件&#xff1a; ①参数可控&#xff1b;&#xff08;从参数输入就知道参数可控&#xff09; ②参数过滤不彻底导致恶意代码被执行&#xff1b;&#xff08;需要在测试过程中判断&#xff09; ③参数带入数据库执行。&#…

C#_扩展方法

简述&#xff1a; 扩展方法所属类必需是静态类&#xff08;类名依据规范通常为XXXExtension&#xff0c;XXX为被扩展类&#xff09;扩展方法必需是公有的静态方法扩展方法的首个参数由this修饰&#xff0c;参数类型为被扩展类型 示例&#xff1a; static class DoubleExtens…

windows安装 RabbitMQ

首先打开 RabbitMQ 官网&#xff0c;点击 Get Started(开始) 点击 Download Installation(下载安装)。 这里提供了两种方式进行安装&#xff0c;我们使用第二种方法。 使用 chocolatey以管理用户身份使用官方安装程序 往下滑&#xff0c;第二种方法需要 Erlang 的依赖&#x…

蓝桥杯14届计算思维国赛U8组包含真题和答案

十四届蓝桥杯国赛考试计算思维 U8 组 答案在底部 第一题 以下选项中,( )是由美国计算机协会设立,对在计算机领域内作出重要贡献的个人授予的奖项 。A.图灵奖 C.菲尔兹奖 B.诺贝尔奖 D.普利策奖 第二题 希希去吃寿司。餐台上摆出了许多食物,可供大家自选。如下图所示。 …

Linux的文件操作,重拳出击( ̄︶ ̄)

Linux的文件操作 学习Linux的文件操作&#xff0c;一般需要知道一个文件如果你想要操作他&#xff0c;必须知道你对这个文件有什么操作的权限或者修改你自己对文件操作的权限。必须要知道文件有三种权限 r&#xff1a;可读 w&#xff1a;可写 x&#xff1a;可执行 在打开Linux…

访问raw.githubusercontent.com失败问题的处理

1 问题 GitHub上的项目的有些资源是放在raw.githubusercontent.com上的&#xff0c;通常我们在安装某些软件的时候会从该地址下载资源&#xff0c;直接访问的话经常容易失败。 # 安装operator kubectl apply -f https://raw.githubusercontent.com/oceanbase/ob-operator/2.1…

PgSQL - 内核特性 - 把DuckDB弄进来怎么样

PgSQL - 内核特性 - 把DuckDB弄进来怎么样 DuckDB是一款高性能的分析型数据库系统&#xff0c;支持了基于Push-based pipeline的向量化执行引擎。这么好的一款数据库&#xff0c;有办法直接弄到PgSQL里面&#xff0c;以利用其优秀的列式存储、向量化执行引擎等优秀特性吗&#…