CSS学习12--清除浮动的本质及处理办法

2024-09-07 13:44

本文主要是介绍CSS学习12--清除浮动的本质及处理办法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

清除浮动

  • 前言
  • 一、清除浮动的本质
  • 二、清除浮动的方法

前言

为什么要清除浮动?
浮动不占用原文档流的位置,可能会对后面的元素排版产生影响。因此需要在该元素中清除浮动,清除浮动后造成的影响。

一、清除浮动的本质

为了解决父级元素因为子级元素引起内部高度为0的问题。

<html><head><style>* {padding: 0;margin: 0;}.box1 {width: 960px;/*height: 100px;*/background-color: red;}.box2 {width: 960px;height: 200px;background-color: purple;}.son1 {width: 150px;height: 100px;background-color: skyblue;float: left;}.son2 {width: 150px;height: 100px;background-color: pink;float: left;}</style></head><body><div class="box1"><div class="son1"></div><div class="son2"></div></div><div class="box2"></div></body>
</html>

父级元素不定义高度是因为不知道盒子里面的内容有多少。
如果son1和son2都浮动了,父级元素没有高度,则会产生重叠。

二、清除浮动的方法

实际上叫做闭合浮动更好,清除浮动是把浮动的盒子圈到里面,让父盒子闭合出口和入口不让他们出来影响其他元素。
在CSS中,clear属性用于清除浮动,基本语法格式:

left
right
both 同时清除左右两侧浮动的影响

  1. 额外标签法

    在浮动盒子的后面添加一个空盒子。

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

    优点:通俗易懂,书写方便
    缺点:添加许多无意义标签,结构化较差,

    <html><head><style>* {padding: 0;margin: 0;}.box1 {width: 960px;/*height: 100px;*/background-color: red;}.box2 {width: 960px;height: 200px;background-color: purple;}.son1 {width: 150px;height: 100px;background-color: skyblue;float: left;}.son2 {width: 150px;height: 100px;background-color: pink;float: left;}.clear {clear: both;}</style></head><body><div class="box1"><div class="son1"></div><div class="son2"></div><div class="clear"></div></div><div class="box2"></div></body>
    </html>
    
  2. 父级添加overflow方法

    给父级添加:overflow为hidden|auto|scroll都可以实现。

    优点:代码简洁
    缺点:内容增多时容易造成不会自动换行导致内容被隐藏,无法显示需要溢出的元素。

    <html><head><style>* {padding: 0;margin: 0;}.box1 {width: 960px;/*height: 100px;*/background-color: red;overflow: hidden; /*触发BFC 清除浮动*/}.box2 {width: 960px;height: 200px;background-color: purple;}.son1 {width: 150px;height: 100px;background-color: skyblue;float: left;}.son2 {width: 150px;height: 100px;background-color: pink;float: left;}</style></head><body><div class="box1"><div class="son1"></div><div class="son2"></div></div><div class="box2"></div></body>
    </html>
    
  3. 使用after伪元素清除浮动

    :after方式为空元素的升级版,好处是不用单独加标签了

    .clearfix:after { content: "."; display: block; height: 0; clear: both; visibility: hidden;}
    .clearfix { *zoom: 1; /**代表ie6.7能识别的*/}
    

    优点:符合闭合浮动思想,结构语义化正确
    缺点:由于IE6-7不支持:after,使用zoom:1触发hasLayout。
    代表网站:百度、网易、淘宝等

    <html><head><style>* {padding: 0;margin: 0;}.box1 {width: 960px;/*height: 100px;*/background-color: red;}.box2 {width: 960px;height: 200px;background-color: purple;}.son1 {width: 150px;height: 100px;background-color: skyblue;float: left;}.son2 {width: 150px;height: 100px;background-color: pink;float: left;}p::after {content: "456";}.clearfix:after { /*:可以*/content: "."; /*内容为小点,尽量加不要空,否则旧版本浏览器有空隙*/display: block; /*转换为块级元素*/height: 0; /*高度为0*/visibility: hidden; /*隐藏盒子*/clear: both;}.clearfix { *zoom: 1; /**代表ie6.7能识别的*/}</style></head><body><p>123</p><div class="box1 clearfix"><div class="son1"></div><div class="son2"></div></div><div class="box2"></div></body>
    </html>
    
  4. 使用双伪元素清除浮动

    .clearfix:before, .clearfix:after { content: ""; display: table;}
    .clearfix:after { clear: both;}
    .clearfix { *zoom: 1; /**代表ie6.7能识别的*/}
    

    优点:代码更简洁
    缺点:由于IE6-7不支持:after,使用zoom:1触发hasLayout。
    代表网站:小米、腾讯等

    <html><head><style>* {padding: 0;margin: 0;}.box1 {width: 960px;/*height: 100px;*/background-color: red;}.box2 {width: 960px;height: 200px;background-color: purple;}.son1 {width: 150px;height: 100px;background-color: skyblue;float: left;}.son2 {width: 150px;height: 100px;background-color: pink;float: left;}p::after {content: "456";}.clearfix:before,.clearfix:after { /*:可以*/content: ""; /*内容为空*/display: table; /*触发bfc 防止外边距合并*/}.clearfix::after {clear: both;}.clearfix { *zoom: 1; /**代表ie6.7能识别的*/}</style></head><body><p>123</p><div class="box1 clearfix"><div class="son1"></div><div class="son2"></div></div><div class="box2"></div></body>
    </html>
    

这篇关于CSS学习12--清除浮动的本质及处理办法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1145221

相关文章

Python处理函数调用超时的四种方法

《Python处理函数调用超时的四种方法》在实际开发过程中,我们可能会遇到一些场景,需要对函数的执行时间进行限制,例如,当一个函数执行时间过长时,可能会导致程序卡顿、资源占用过高,因此,在某些情况下,... 目录前言func-timeout1. 安装 func-timeout2. 基本用法自定义进程subp

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

浅析Java中如何优雅地处理null值

《浅析Java中如何优雅地处理null值》这篇文章主要为大家详细介绍了如何结合Lambda表达式和Optional,让Java更优雅地处理null值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录场景 1:不为 null 则执行场景 2:不为 null 则返回,为 null 则返回特定值或抛出异常场景

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

深入理解Apache Kafka(分布式流处理平台)

《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

resultMap如何处理复杂映射问题

《resultMap如何处理复杂映射问题》:本文主要介绍resultMap如何处理复杂映射问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录resultMap复杂映射问题Ⅰ 多对一查询:学生——老师Ⅱ 一对多查询:老师——学生总结resultMap复杂映射问题