【重识 HTML + CSS

Rule1:定位元素会层叠在浮动元素上面:

在这里插入图片描述

Rule2:浮动元素不能与行内级内容层叠,行内级内容将会被浮动元素推出

  • 比如行内级元素、inline-block元素、块级元素的文字内容

在这里插入图片描述

  • 利用此特性,可以轻松实现文字环绕功能:[浮动-文字环绕练习](()

在这里插入图片描述

Rule3:行内级元素、inline-block 元素浮动后,其顶部将与所在行的顶部对齐

在这里插入图片描述

实现代码:[float-rule_01-其他](()

Rule4:如果元素是向左(右)浮动,浮动元素的左(右)边界不能超出包含块的左(右)边界

在这里插入图片描述

带圆圈的数字,标记着浮动元素浮动之前的位置

Rule5:浮动元素之间不能层叠

  • 如果一个元素浮动,另一个浮动元素已经在那个位置了,后浮动的元素将紧贴着前一个浮动元素(左浮找左浮,右浮找右浮)

  • 如果水平方向剩余的空间不够显示浮动元素,浮动元素将向下移动,直到有充足的空间为止

在这里插入图片描述

Rule6:浮动元素的顶端不能超过包含块的顶端,也不能超过之前所有浮动元素的顶端

在这里插入图片描述

示例代码:[float-rule_01](()、[float-rule_02](()、[float-rule_02-其他](()、[float-rule_03](()

[](()浮动的应用


浮动常用的场景:

  • 解决行内级元素、inline-block 元素的水平间隙问题

在这里插入图片描述

  • 布局

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

[](()浮动存在的问题:高度坍塌


由于浮动元素脱离了标准流,变成了脱标元素,所以不再向父元素汇报高度

父元素计算总高度时,就不会计算浮动子元素的高度,导致了高度坍塌的问题

解决父元素高度坍塌问题的过程,一般叫做 清浮动(清理浮动、清除浮动)

  • 清浮动的目的:让父元素计算总高度的时候,把浮动子元素的高度算进去

代码:[浮动的问题](()

[](()清浮动的常见方法


给父元素设置固定高度

  • 扩展性不好(不推荐)

  • 代码: 《大厂前端面试题解析+Web核心总结学习笔记+企业项目实战源码+最新高清讲解视频》无偿开源 徽信搜索公众号【编程进阶路】 [清浮动-01](()

让父元素浮动

  • 可能导致页面中所有元素都浮动

  • 父元素脱离了标准流

  • 改变了元素的盒子特性(不推荐)

  • 代码:[清浮动-02](()

让父元素成为绝对定位元素(position 设置为 absolute 或 fixed)

  • 父元素脱离了标准流

  • 改变了元素的盒子特性(不推荐)

  • 代码:[清浮动-03](()

给父元素设置 display 为 inline-block、inline-table、table、table-cell、table-caption

  • 改变了父元素的盒子特性(不推荐)

  • 代码:[清浮动-04](()

给父元素设置 overflow 为 visible 以外的值(比如 hidden、auto、scroll)

  • 改变了父元素对内容溢出的默认行为(不推荐)

  • 代码:[清浮动-05](()

在父元素最后增加一个空的块级子元素,并且让它设置 clear: both

  • 会增加很多无意义的空标签,维护麻烦

  • 违反了结构与样式分离的原则(不推荐)

  • 代码:[清浮动-06](()

在父元素最后增加一个 br 标签<br clear="all">

  • 会增加很多无意义的空标签,维护麻烦

  • 违反了结构与样式分离的原则(不推荐)

  • 代码:[清浮动-07](()

以上方法都不推荐,简单了解即可

给父元素增加 ::after 伪元素

  • 纯 CSS 样式解决,结构与样式分离(推荐

.clear-fix::after {

content: “”;

display: block;

clear: both;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值