标准流

CSS标准流(CSS normal flow)是指在HTML文档中,元素按照其在文档中出现的顺序进行自然布局的方式。大家都堆过积木吧,堆的过程中是按照从下到上,先搭建地基,然后再慢慢延申到上面,对比css基本上是相同的,但是搭建的顺序变了一下,现在是从上到下。这就像大家写作文一样,一般都是先写题目,写主题,然后分段落写其他内容。标准流指的就是按照文档中先后顺序进行布局。如果在html语句中先写一个div,那么这个div就在标准流的上方显示。

示例:多个div嵌套书写

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>CSS</title>
    <style>
        .head{
            background-color: pink;
        }
        .contain{
            background-color: blue;
        }
        .footer{
            background-color: antiquewhite;
        }
        .contain div:nth-child(1){
            background-color: blueviolet;
        }
        .contain div:nth-child(2){
            background-color:white;
        }
    </style>
</head>
<body>
    <div class="head">
        123
    </div>
    <div class="contain">
        456
        <div>
                abc
        </div>
        <div>
                efg
        </div>
    </div>
    <div class="footer">
        789
    </div>
</body>
</html>

CSS浮动(详解)_清除浮动

按照html中的书写顺序,进行排列,当人修改对应的元素属性,也可以达到其他效果。

CSS浮动(详解)_css_02

浮动

为什么需要浮动?

在实际开发中,当我们想要实现很多布局效果,但是标准流无法实现,所以此时就需要使用浮动来增加显示效果。

举例:

当我们需要一个左侧图片右侧文字的效果时,你会怎么做?

使用行内块元素也可以解决上面的情况,那这种呢?图片在右侧,文字在左侧。

CSS浮动(详解)_CSS_03

浮动写法:float:属性值;

属性值

描述

left

元素向左浮动

right

元素向右浮动

none

元素不浮动(默认值)

浮动特性

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>
    <style>
        .first{
            width: 300px;
            height: 300px;
            background-color: pink;
        }
        .second{
            width: 200px;
            height: 200px;
            background-color: purple;
        }
        .second-son{
            float: left;
            width: 50px;
            height: 50px;
            background-color: red;
        }
        .second-litterson{
            width: 100px;
            height: 100px;
            background-color: brown;
        }
    </style>
</head>
<body>
    <div class="first">
        123
    </div>
    <div class="second">
        <div class="second-son"></div>
        <div class="second-litterson">happy happy!</div>
    </div>
    <div style="width: 100px; height: 100px; background-color: black;"></div>
</body>
</html>
代码分析:

3个大的div盒子,第二个盒子中有两个小盒子,一个设置浮动,一个没有设置,设置浮动的脱离标准流显示在父盒子左侧(float:left)此时不占有原来位置,后面的棕色盒子显示第二个盒子开始位置。并且红色盒子是覆盖一部分棕色盒子,棕色盒子的文字围绕红色盒子展示。

浮动的元素对后面与父类同级的元素没影响。因为父类没设置浮动。只有当改浮动元素超出父类盒子时,会影响后面的元素显示。

CSS浮动(详解)_清除浮动_04

CSS浮动(详解)_清除浮动_05

3.浮动更改元素的显示方式
浮动可以改变元素的显示方式,把它从默认的块级元素变成行内块级元素。这是因为浮动元素在布局时会脱离文档流,并且尺寸会自适应内容,因此会出现不同于默认情况下的框类型。另外,浮动元素在与文本混排时,其高度也会自适应内容,而不是默认的单行高度。
4.浮动元素掉落
多个浮动元素在同一行浮动时,当元素宽度大于父盒子宽度,浮动元素会在下一行按浮动类型显示

清除浮动

1.使用空的 <div> 元素进行清除: 在浮动元素的末尾添加一个空的 <div> 元素,并为其设置 clear: both; 样式属性。这将在浮动元素下方创建一个空白元素,使得父容器能够正确地包围浮动元素。
 

<div style="clear: both;"></div>

2.使用伪元素进行清除(推荐使用):  ::after 伪元素为父容器添加一个空的块级元素,并应用 clear: both; 样式属性。这种方法可以避免额外的HTML元素。

.clearfix::after {
  content: "";
  display: table;
  clear: both;
}

.clearfix 类样式应用于包含浮动元素的父容器。

3.使用 clearfix 类进行清除: 定义一个 clearfix 类,并应用于包含浮动元素的父容器。通过在父容器上添加 clearfix 类,将自动清除浮动。

.clearfix {
  clear: both;
}
<div class="clearfix">
  <!-- 浮动元素 -->
</div>

4.使用 overflow 属性进行清除: 将父容器的 overflow 属性设置为 autohidden。这将创建一个新的BFC(块格式化上下文)来包含浮动元素。

.parent-container {
  overflow: auto; /* 或者使用 overflow: hidden; */
}

这里贴一篇大佬的博客,要是读者没看明白可以看一下这个:

浮动(Float)_float浮动-

在使用浮动时,需要时刻保持注意,确保正确地应用它并避免它带来的负面影响。同时,选择合适的清除浮动方法也是非常关键的。通过本文的介绍,希望读者能够更好地理解和掌握CSS中浮动的应用方法和技巧,从而提高Web开发的效率。