CSS 常用样式浮动属性
一、概述
CSS 中,浮动属性的作用是让元素向左或向右浮动,使其他元素围绕它排布,常用的浮动属性有以下几种:
-
float: left; 使元素向左浮动,其他元素从右侧包围它。
-
float: right; 使元素向右浮动,其他元素从左侧包围它。
-
float: none; 取消元素的浮动状态。
浮动属性常用于网页布局中,可以使元素实现多栏布局、文字环绕图片等效果。需要注意的是,浮动元素会脱离文档流,可能会影响页面其他元素的布局,需要使用 clear 属性清除浮动影响。同时,如果浮动的元素宽度超过了父元素宽度,需要设置 overflow:hidden; 或者使用 clearfix 来清除浮动。
除了以上提到的三种常用的浮动属性,还有一些其他的浮动属性,如 clear、float-direction 等,可以根据具体需求选择使用。但是需要注意的是,过多的浮动属性使用会增加代码复杂度,导致维护困难,建议适度使用。
二、浮动的性质
CSS 中的浮动是一种布局方式,常用于实现图片或者文本环绕效果。它的属性值包括 left
、right
、none
和 inherit
。
下面是浮动的具体性质:
-
浮动元素会脱离文档流,不再占据原来的位置。这意味着其他元素会尝试占据浮动元素的位置。
-
浮动元素会向左或向右移动,直到它的外边缘碰到包含它的容器边缘或者另一个浮动元素的边缘。
-
浮动元素可以和其他元素重叠。
-
包含浮动元素的容器高度无法被浮动元素撑起,需要使用
clear
属性清除浮动元素对容器的影响。
下面是一个浮动元素的示例:
<div class="container"><div class="box">Box 1</div><div class="box">Box 2</div><div class="box float">Box 3</div><div class="box">Box 4</div>
</div>
.container {width: 500px;height: 500px;background-color: #ccc;
}.box {width: 100px;height: 100px;margin: 10px;background-color: #fff;float: left;
}.float {float: right;
}
在这个例子中,Box 3 使用了 float: right
属性,所以它会向右浮动。它的外边缘碰到了容器的右边缘,所以停止了移动。由于 Box 3 浮动了,容器的高度无法被撑起,需要使用 clear
属性清除浮动元素对容器的影响,代码如下:
.container::after {content: "";display: block;clear: both;
}
参考链接:
- MDN Web 文档:浮动
三、浮动的问题
CSS浮动是一种常用的布局方式,它可以使网页中的元素沿着指定的方向浮动,从而实现复杂的页面布局。但是,浮动也会带来一些问题,比如元素高度塌陷、浮动元素重叠等。接下来将详细解析这些问题并提供相应的代码实例。
问题1:元素高度塌陷
当一个浮动元素后面没有其他元素或者该元素的父元素没有设置高度时,该元素的高度会塌陷,导致后面的元素布局异常。这是因为浮动元素脱离了文档流,不能撑开父元素的高度。
解决方法:
1.设置父元素的高度,可以通过设置固定值或者使用min-height。
<div class="parent" style="min-height: 200px;"><div class="float">浮动元素</div><div>后面的元素</div>
</div>
2.在浮动元素后面添加一个空的块元素并设置clear属性,这个元素会撑开父元素高度。
<div class="parent"><div class="float">浮动元素</div><div class="clear"></div><div>后面的元素</div>
</div><style>
.clear {clear: both;
}
</style>
问题2:浮动元素重叠
当多个浮动元素在同一行,宽度之和超过父元素宽度时,后面的浮动元素会被挤到下一行。
解决方法:
1.使用flex布局,可以自动调整浮动元素的位置。
<div class="parent" style="display: flex; flex-wrap: wrap;"><div class="float">浮动元素1</div><div class="float">浮动元素2</div><div class="float">浮动元素3</div><div class="float">浮动元素4</div><div class="float">浮动元素5</div>
</div>
2.设置浮动元素的宽度为百分比,使浮动元素自适应父元素宽度。
<div class="parent"><div class="float" style="width: 20%;">浮动元素1</div><div class="float" style="width: 20%;">浮动元素2</div><div class="float" style="width: 20%;">浮动元素3</div><div class="float" style="width: 20%;">浮动元素4</div><div class="float" style="width: 20%;">浮动元素5</div>
</div>
问题3:父元素无法包含浮动元素
当父元素的高度为0时,浮动元素会溢出父元素,导致布局出现问题。
解决方法:
1.使用overflow属性,父元素设置为auto、hidden或scroll,可以使父元素包含浮动元素。
<div class="parent" style="overflow: auto;"><div class="float">浮动元素</div>
</div>
2.使用clearfix方法,给父元素添加一个clearfix类,该类包含一个clearfix伪元素,在父元素内部产生一个清除浮动的效果。
<div class="parent clearfix"><div class="float">浮动元素</div>
</div><style>
.clearfix::after {content: "";display: table;clear: both;
}
</style>
以上就是CSS浮动的问题及相应的解决方法,通过这些方法可以避免浮动带来的问题,实现更加复杂且美观的页面布局。
四、清除浮动方法
浮动(float)是 CSS 中很常用的属性,它可以让元素像浮动在文档流的上面,达到排版和布局的目的。但是,浮动元素可能会影响到其他元素的布局,导致布局混乱。
为了解决浮动元素带来的布局问题,可以使用清除浮动(clear float)的方法。常见的清除浮动方法有以下几种:
- 使用清除浮动的伪类:after
在浮动元素的父元素上使用 :after
伪类,并给它设置 content: "."; display: block; height: 0; clear:both; visibility: hidden;
,可以清除浮动导致的父元素高度塌陷问题。代码实现如下:
.clearfix:after {content: ".";display: block;height: 0;clear:both;visibility: hidden;
}
在 HTML 中,只需要在浮动元素的父元素上添加 clearfix
类名即可。
<div class="clearfix"><div class="float-left"></div><div class="float-left"></div>
</div>
- 使用 overflow 属性清除浮动
在浮动元素的父元素上设置 overflow: auto;
或 overflow: hidden;
,可以清除浮动导致的父元素高度塌陷问题。代码实现如下:
.parent {overflow: auto;
}
- 使用 display 属性清除浮动
在浮动元素的父元素上设置 display: table;
或 display: table-cell;
,可以清除浮动导致的父元素高度塌陷问题。代码实现如下:
.parent {display: table;
}
- 使用双伪元素清除浮动
在浮动元素的父元素上使用双伪元素(:before
和 :after
)清除浮动,可以清除浮动导致的父元素高度塌陷问题。代码实现如下:
.parent:before,
.parent:after {content: "";display: table;
}
.parent:after {clear:both;
}
需要注意的是,使用浮动布局时,应该在需要浮动的元素后面添加清除浮动的元素,保证布局的正确性。
相关文章:
CSS 常用样式浮动属性
一、概述 CSS 中,浮动属性的作用是让元素向左或向右浮动,使其他元素围绕它排布,常用的浮动属性有以下几种: float: left; 使元素向左浮动,其他元素从右侧包围它。 float: right; 使元素向右浮动,其他元素…...

Linux引导故障排除:从问题到解决方案的详细指南
1 BIOS初始化 通电->对硬件检测->初始化硬件时钟 2 磁盘引导及其修复 2.1 磁盘引导故障 磁盘主引导记录(MBR)是在0磁道1扇区位置,446字节。 MBR作用:记录grub2引导文件的位置 2.2 修复 步骤:1、光盘进…...
【vim 学习系列文章 6 -- vim 如何从上次退出的位置打开文件】
文章目录 1.1 vim 如何从上次退出的位置打开文件1.2 autogroup 命令学习1.2.1 augroup 基本语法 1.3 vim call 命令详细介绍 1.1 vim 如何从上次退出的位置打开文件 假设我打开了文件 test.c,然后我向下滚动到第 50 行,然后我做了一些修改并关闭了文件。…...

怎样学习C#上位机编程?
怎样学习C#上位机编程? 00001. 掌握C#编程和.NET框架基础。 00002. 学WinForm应用开发,了解控件使用和事件编程。 00003. 熟悉基本数据结构和算法,如链表、栈、队列。 00004. 理解串口通信协议和方法,用于与硬件交互。 00005…...

【算法-动态规划】两个字符串的删除操作-力扣 583
💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学…...
【06】基础知识:typescript中的泛型
一、泛型的定义 在软件开发中,我们不仅要创建一致的定义良好的API,同时也要考虑可重用性。 组件不仅能支持当前数据类型,同时也能支持未来的数据类型,这在创建大型系统时提供了十分灵活的功能。 在像 C# 和 Java 这样的语言中&…...

flutter 绘制原理探究
文章目录 Widget1、简介2、源码分析Element1、简介2、源码分析RenderObjectWidget 渲染过程总结思考Flutter 的核心设计思想便是“一切皆 Widget”,Widget 是 Flutter 功能的抽象描述,是视图的配置信息,同样也是数据的映射,是 Flutter 开发框架中最基本的概念。 在 Flutter…...
[Java]SPI扩展功能
一、什么是SPI Java SPI(Service Provider Interface)是Java官方提供的一种服务发现机制。 它允许在运行时动态地加载实现特定接口的类,而不需要在代码中显式地指定该类,从而实现解耦和灵活性。 二、实现原理 基于 Java 类加载…...

机器人命令表设计
演算命令 CLEAR 将数据 1 上被指定的编号以后的变数的内容,以及数据 2 上仅被指定的个数都清除至 0。 INC 在被指定的变数内容上加上 1。 DEC 在被指定的变数内容上减掉 1。 SET 在数据 1 上设定数据 2。 ADD 将数据 1 和数据 2 相加,得出的结果保存在数…...

STM32--WDG看门狗
文章目录 WDG简介IWDGIWDG的超时计算WWDGWWDG超时和窗口值设定独立看门狗工程WWDG工程 WDG简介 WDG看门狗(Watchdog Timer)是一种常见的硬件设备,在STM32F10系列中,有两种看门狗,分别是独立看门狗和窗口看门狗&#x…...
(※)力扣刷题-字符串-实现 strStr()(KMP算法)
28 实现 strStr() 实现 strStr() 函数。 给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在,则返回 -1。 示例 1: 输入: haystack “hello”, needle “ll” 输出: 2 示例…...

Redis 集群 Redis 事务 Redis 流水线 Redis 发布订阅 Redis Lua脚本操作
Redis 集群 & Redis 事务 & Redis 流水线 & Redis 发布订阅 Redis 集群linux安装redis主从配置查看当前实例主从信息 Redis Sentinelsentinel Redis Cluster Redis 事务Redis 流水线Redis 发布订阅Redis Lua脚本操作 Redis 集群 linux安装redis 下载安装包&#…...
【算法与数据结构】--常见数据结构--栈和队列
一、栈 栈(Stack) 是一种基本的数据结构,具有后进先出(LIFO)的特性,类似于现实生活中的一叠盘子。栈用于存储一组元素,但只允许在栈顶进行插入(入栈)和删除(…...

Linux shell编程学习笔记11:关系运算
Linux Shell 脚本编程和其他编程语言一样,支持算数、关系、布尔、字符串、文件测试等多种运算。前面几节我们研究了 Linux shell编程 中的 字符串运算 和 算术运算,今天我们来研究 Linux shell编程中的的关系运算。 一、关系运算符功能说明 运算符说明…...
JS标准库
学习一门编程语言不仅是掌握其语法。同等重要的是学习其标准库,从而熟练掌握语言本身提供的所有工具。 1 定型数组 js常规数组与C和Java等较低级语言的数组类型还是有很大区别。ES6新增了定型数组,与这些语言的低级数组非常接近。 定型数组严格来说并…...
Android 12.0 hal层添加自定义hal模块功能实现
1. 前言 在12.0的系统rom定制化开发中,在 对hal模块进行开发时,需要通过添加自定义的hal模块来实现某些功能时,就需要添加hal模块的相关功能,接下来就来实现一个案例来供参考 接下来就来具体实现这个功能 2.hal层添加自定义hal模块功能实现的核心类 hardware\interfaces…...
如何理解vue声明式渲染
Vue.js中的声明式渲染是一种用来描述用户界面的方式,它强调“声明”应该如何渲染页面,而不需要关心底层的DOM操作。这与传统的命令式渲染方式,即手动控制DOM元素的创建、更新和销毁,形成了鲜明的对比。 理解Vue的声明式渲染的关键…...
【已解决】Vue全局引入scss 个别页面不生效 / 不自动引入全局样式
项目里配置了全局样式的引入,今天新建了 demo 页面去修改 element 的样式,发现全局的样式没有引入进来。 问题原因 在此页面 没有任何样式导致的 项目在编译的时候,会把 .vue 文件的样式抽离到单独的 css 文件中。 当该页面没有css代码的时…...

MySQL之双主双从读写分离
一个主机 Master1 用于处理所有写请求,它的从机 Slave1 和另一台主机 Master2 还有它的从 机 Slave2 负责所有读请求。当 Master1 主机宕机后, Master2 主机负责写请求, Master1 、 Master2 互为备机。架构图如下 : 准备 我们…...

使用eBPF加速阿里云服务网格ASM
背景 随着云原生应用架构的快速发展,微服务架构已经成为了构建现代应用的主要方式之一。而在微服务架构中,服务间的通信变得至关重要。为了实现弹性和可伸缩性,许多组织开始采用服务网格技术来管理服务之间的通信。 Istio作为目前最受欢迎的…...

UE5 学习系列(二)用户操作界面及介绍
这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…...

智慧医疗能源事业线深度画像分析(上)
引言 医疗行业作为现代社会的关键基础设施,其能源消耗与环境影响正日益受到关注。随着全球"双碳"目标的推进和可持续发展理念的深入,智慧医疗能源事业线应运而生,致力于通过创新技术与管理方案,重构医疗领域的能源使用模式。这一事业线融合了能源管理、可持续发…...

shell脚本--常见案例
1、自动备份文件或目录 2、批量重命名文件 3、查找并删除指定名称的文件: 4、批量删除文件 5、查找并替换文件内容 6、批量创建文件 7、创建文件夹并移动文件 8、在文件夹中查找文件...
Objective-C常用命名规范总结
【OC】常用命名规范总结 文章目录 【OC】常用命名规范总结1.类名(Class Name)2.协议名(Protocol Name)3.方法名(Method Name)4.属性名(Property Name)5.局部变量/实例变量(Local / Instance Variables&…...

微信小程序 - 手机震动
一、界面 <button type"primary" bindtap"shortVibrate">短震动</button> <button type"primary" bindtap"longVibrate">长震动</button> 二、js逻辑代码 注:文档 https://developers.weixin.qq…...

《通信之道——从微积分到 5G》读书总结
第1章 绪 论 1.1 这是一本什么样的书 通信技术,说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号(调制) 把信息从信号中抽取出来&am…...
Linux云原生安全:零信任架构与机密计算
Linux云原生安全:零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言:云原生安全的范式革命 随着云原生技术的普及,安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测,到2025年,零信任架构将成为超…...
今日科技热点速览
🔥 今日科技热点速览 🎮 任天堂Switch 2 正式发售 任天堂新一代游戏主机 Switch 2 今日正式上线发售,主打更强图形性能与沉浸式体验,支持多模态交互,受到全球玩家热捧 。 🤖 人工智能持续突破 DeepSeek-R1&…...

深入解析C++中的extern关键字:跨文件共享变量与函数的终极指南
🚀 C extern 关键字深度解析:跨文件编程的终极指南 📅 更新时间:2025年6月5日 🏷️ 标签:C | extern关键字 | 多文件编程 | 链接与声明 | 现代C 文章目录 前言🔥一、extern 是什么?&…...
Rapidio门铃消息FIFO溢出机制
关于RapidIO门铃消息FIFO的溢出机制及其与中断抖动的关系,以下是深入解析: 门铃FIFO溢出的本质 在RapidIO系统中,门铃消息FIFO是硬件控制器内部的缓冲区,用于临时存储接收到的门铃消息(Doorbell Message)。…...