CSS学习笔记-05-浮动

笔记来源:
【狂神说Java】CSS3最新教程快速入门通俗易懂

5、浮动


5.1、标准文档流

标准文档流图片

文档流

  • 网页是一个多层的结构,一层摞着一层
  • 通过CSS可以分别为每一层设置样式
  • 用户只能看到最顶上一层
  • 这些层中,最底下一层称为文档流,文档流是网页的基础,我们所创建的元素默认都是再文档流中进行排列
  • 对我我们来说元素又两个状态(在文档流中,不在文档流中)
  • 元素在文档流中有什么特点:
    • 块元素
      • 块元素会在页面独占一行
      • 默认宽度是父元素的全部(把父元素撑满)
      • 默认高度是被内容撑开的
    • 行内元素
      • 行内元素不会独占页面的一行,只占自身的大小
      • 行内元素在页面中左向右水平排列,如果一行之中不能容纳所有的行内元素,则行内元素会换到第二行继续自左向右(书写习惯一致)
      • 行内元素的默认高度和宽度都是被内容撑开

块级元素:独占一行

h1~h6    p  div  列表

行内元素

span a img strong.....

行内元素可以被包含在块级元素中,反之,则不可以

5.2、display

<!--
    block 块元素
    inline 行内元素
    inline-block 是块元素但可以内联在一行

-->
    <style>
        div{
    
    
            width: 100px;
            height: 100px;
            border: 1px solid red;
        }
        span{
    
    
            width: 100px;
            height: 100px;
            border: 1px solid rebeccapurple;
            display: block;
        }
    </style>

这个也是一种实现行内元素排列的方式,但大多情况都是用float

5.3、float

  • 通过浮动可以使一个元素向其父元素的左侧和右侧移动

    使用float属性可以设置元素的浮动

    可选值:

    • none:默认值,元素不浮动
    • left:元素向左浮动
    • right:元素向右浮动
  • 注意:元素设置浮动后,水平布局的等式便不需要强制成立

  • 元素设置浮动后,会完全从文档流中脱离,不再占用文档流的位置,所以元素下边的还在文档流中的元素会自动向上移动

浮动的特点:

  • 1、浮动元素会完全脱离文档流,不会占据文档流中的位置
  • 2、设置浮动以后元素会向父元素的左侧或右侧移动
  • 3、浮动元素默认不会从父元素中移出
  • 4、浮动元素向左向右移动时,不会超出它前边的其它浮动元素
  • 5、如果浮动元素的上边是一个没有浮动的块元素,则浮动元素无法上移
  • 6、浮动元素不会超过它上边的浮动的兄弟元素,最多最多就是和他一样高
  • 总结:通过浮动可以制造一些水平方向的布局

浮动的其它特点:

  • 元素设置浮动以后,会从文档流中脱离,从文档流中脱离后,元素的一些特点也会发生变化

  • 脱离文档流的特点:

    • 块元素:
      • 1、块元素不再独占页面的一行
      • 2、脱离文档流后,块元素的宽度和高度都默认为被内容撑开
    • 行内元素:
      • 行内元素脱离文档流后就会变成块元素,特点和块元素一样
    • 脱离文档流后,就不需要再区分块元素和行内元素了

在这里插入图片描述

在这里插入图片描述

5.4、父级边框塌陷的问题

  • 在浮动布局中,父元素的高度默认是被子元素撑开的

    当子元素浮动后,其会完全脱离文档流,子元素会从文档流中脱离,将会无法撑起父元素的高度,导致父元素高度丢失

  • 父元素高度丢失以后,其下的元素会自动上移,导致页面的布局混乱,所以高度塌陷是浮动布局中比较常见的一个问题,这个问题我们必须进行处理!

解决方案:

1.增加父级元素的高度

在这里插入图片描述

2.增加一个空的div标签,清除浮动

3.overflow(开启BFC

在父级元素中增加一个overflow:hidden;

4、父类添加一个伪类:after

在这里插入图片描述

小结:

1.浮动元素后面增加空div

​ 简单,代码中尽量避免空div

2.设置父元素的高度

​ 简单,元素假设有了固定的高度,就会被限制

3.overflow

​ 简单,下拉的一些场景不能使用

4.在父类添加伪类(推荐使用)

写法稍微复杂,但没有副作用

5.5、BFC

  • BFC(Block Formatting Context)块级格式化环境

    • BFC是一个CSS中的一个隐含的属性,可以为一个元素开启BFC

      开启BFC该元素会变成一个独立的布局区域

    • 元素开启BFC后的特点

      • 开启BFC的元素不会被浮动元素所覆盖
      • 开启BFC的元素和父元素外边距不会重叠
      • 开启BFC的元素可以包含浮动的子元素
  • 可以通过一些特殊的方法来开启元素的BFC

    • 1、设置元素的浮动(不推荐)
    • 2、将元素设置为行内块元素(不推荐)
    • 3、将元素的overflow设置为一个非visible的值(推荐)
    • 常用的方式:设置overflow:hidden开启BFC,

5.6、clear

在这里插入图片描述

如果我们不希望某个元素因为其它元素浮动的影响而改变位置,可以通过clear属性来清除浮动元素对当前元素所产生的影响

clear:

  • 作用:清除浮动元素对当前元素所产生的影响

  • 可选值如上图所示

    原理:

    ​ 设置清除浮动以后,浏览器会自动为元素添加一个上外边距,以使其位置不受其它元素的影响

5.7、高度塌陷的最终解决方案(使用伪类)

.box1::after{
    
    
    content:"";
    display:block;
    clear:both;
}

完美解决塌陷问题

5.8、clearfix

clearfix这个样式可以同时解决高度塌陷和外边距重叠的问题,当你在遇到这些问题时,直接使用clearfix这个类即可

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

5.9、对比

  • display

    方向不可控制

  • float

    浮动起来会脱离标准文档流,所以要解决父级边框塌陷的问题~

猜你喜欢

转载自blog.csdn.net/weixin_53249168/article/details/128159297