当前位置: 首页 > news >正文

CSS 常用样式浮动属性

一、概述

CSS 中,浮动属性的作用是让元素向左或向右浮动,使其他元素围绕它排布,常用的浮动属性有以下几种:

  1. float: left; 使元素向左浮动,其他元素从右侧包围它。

  2. float: right; 使元素向右浮动,其他元素从左侧包围它。

  3. float: none; 取消元素的浮动状态。

浮动属性常用于网页布局中,可以使元素实现多栏布局、文字环绕图片等效果。需要注意的是,浮动元素会脱离文档流,可能会影响页面其他元素的布局,需要使用 clear 属性清除浮动影响。同时,如果浮动的元素宽度超过了父元素宽度,需要设置 overflow:hidden; 或者使用 clearfix 来清除浮动。

除了以上提到的三种常用的浮动属性,还有一些其他的浮动属性,如 clear、float-direction 等,可以根据具体需求选择使用。但是需要注意的是,过多的浮动属性使用会增加代码复杂度,导致维护困难,建议适度使用。

二、浮动的性质

CSS 中的浮动是一种布局方式,常用于实现图片或者文本环绕效果。它的属性值包括 leftrightnoneinherit

下面是浮动的具体性质:

  1. 浮动元素会脱离文档流,不再占据原来的位置。这意味着其他元素会尝试占据浮动元素的位置。

  2. 浮动元素会向左或向右移动,直到它的外边缘碰到包含它的容器边缘或者另一个浮动元素的边缘。

  3. 浮动元素可以和其他元素重叠。

  4. 包含浮动元素的容器高度无法被浮动元素撑起,需要使用 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)的方法。常见的清除浮动方法有以下几种:

  1. 使用清除浮动的伪类: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>

  1. 使用 overflow 属性清除浮动

在浮动元素的父元素上设置 overflow: auto;overflow: hidden;,可以清除浮动导致的父元素高度塌陷问题。代码实现如下:

.parent {overflow: auto;
}

  1. 使用 display 属性清除浮动

在浮动元素的父元素上设置 display: table;display: table-cell;,可以清除浮动导致的父元素高度塌陷问题。代码实现如下:

.parent {display: table;
}

  1. 使用双伪元素清除浮动

在浮动元素的父元素上使用双伪元素(:before:after)清除浮动,可以清除浮动导致的父元素高度塌陷问题。代码实现如下:

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

需要注意的是,使用浮动布局时,应该在需要浮动的元素后面添加清除浮动的元素,保证布局的正确性。

相关文章:

CSS 常用样式浮动属性

一、概述 CSS 中&#xff0c;浮动属性的作用是让元素向左或向右浮动&#xff0c;使其他元素围绕它排布&#xff0c;常用的浮动属性有以下几种&#xff1a; float: left; 使元素向左浮动&#xff0c;其他元素从右侧包围它。 float: right; 使元素向右浮动&#xff0c;其他元素…...

Linux引导故障排除:从问题到解决方案的详细指南

1 BIOS初始化 通电->对硬件检测->初始化硬件时钟 2 磁盘引导及其修复 2.1 磁盘引导故障 磁盘主引导记录&#xff08;MBR&#xff09;是在0磁道1扇区位置&#xff0c;446字节。 MBR作用&#xff1a;记录grub2引导文件的位置 2.2 修复 步骤&#xff1a;1、光盘进…...

【vim 学习系列文章 6 -- vim 如何从上次退出的位置打开文件】

文章目录 1.1 vim 如何从上次退出的位置打开文件1.2 autogroup 命令学习1.2.1 augroup 基本语法 1.3 vim call 命令详细介绍 1.1 vim 如何从上次退出的位置打开文件 假设我打开了文件 test.c&#xff0c;然后我向下滚动到第 50 行&#xff0c;然后我做了一些修改并关闭了文件。…...

怎样学习C#上位机编程?

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

【算法-动态规划】两个字符串的删除操作-力扣 583

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学…...

【06】基础知识:typescript中的泛型

一、泛型的定义 在软件开发中&#xff0c;我们不仅要创建一致的定义良好的API&#xff0c;同时也要考虑可重用性。 组件不仅能支持当前数据类型&#xff0c;同时也能支持未来的数据类型&#xff0c;这在创建大型系统时提供了十分灵活的功能。 在像 C# 和 Java 这样的语言中&…...

flutter 绘制原理探究

文章目录 Widget1、简介2、源码分析Element1、简介2、源码分析RenderObjectWidget 渲染过程总结思考Flutter 的核心设计思想便是“一切皆 Widget”,Widget 是 Flutter 功能的抽象描述,是视图的配置信息,同样也是数据的映射,是 Flutter 开发框架中最基本的概念。 在 Flutter…...

[Java]SPI扩展功能

一、什么是SPI Java SPI&#xff08;Service Provider Interface&#xff09;是Java官方提供的一种服务发现机制。 它允许在运行时动态地加载实现特定接口的类&#xff0c;而不需要在代码中显式地指定该类&#xff0c;从而实现解耦和灵活性。 二、实现原理 基于 Java 类加载…...

机器人命令表设计

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

STM32--WDG看门狗

文章目录 WDG简介IWDGIWDG的超时计算WWDGWWDG超时和窗口值设定独立看门狗工程WWDG工程 WDG简介 WDG看门狗&#xff08;Watchdog Timer&#xff09;是一种常见的硬件设备&#xff0c;在STM32F10系列中&#xff0c;有两种看门狗&#xff0c;分别是独立看门狗和窗口看门狗&#x…...

(※)力扣刷题-字符串-实现 strStr()(KMP算法)

28 实现 strStr() 实现 strStr() 函数。 给定一个 haystack 字符串和一个 needle 字符串&#xff0c;在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在&#xff0c;则返回 -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 下载安装包&#…...

【算法与数据结构】--常见数据结构--栈和队列

一、栈 栈&#xff08;Stack&#xff09; 是一种基本的数据结构&#xff0c;具有后进先出&#xff08;LIFO&#xff09;的特性&#xff0c;类似于现实生活中的一叠盘子。栈用于存储一组元素&#xff0c;但只允许在栈顶进行插入&#xff08;入栈&#xff09;和删除&#xff08;…...

Linux shell编程学习笔记11:关系运算

Linux Shell 脚本编程和其他编程语言一样&#xff0c;支持算数、关系、布尔、字符串、文件测试等多种运算。前面几节我们研究了 Linux shell编程 中的 字符串运算 和 算术运算&#xff0c;今天我们来研究 Linux shell编程中的的关系运算。 一、关系运算符功能说明 运算符说明…...

JS标准库

学习一门编程语言不仅是掌握其语法。同等重要的是学习其标准库&#xff0c;从而熟练掌握语言本身提供的所有工具。 1 定型数组 js常规数组与C和Java等较低级语言的数组类型还是有很大区别。ES6新增了定型数组&#xff0c;与这些语言的低级数组非常接近。 定型数组严格来说并…...

Android 12.0 hal层添加自定义hal模块功能实现

1. 前言 在12.0的系统rom定制化开发中,在 对hal模块进行开发时,需要通过添加自定义的hal模块来实现某些功能时,就需要添加hal模块的相关功能,接下来就来实现一个案例来供参考 接下来就来具体实现这个功能 2.hal层添加自定义hal模块功能实现的核心类 hardware\interfaces…...

如何理解vue声明式渲染

Vue.js中的声明式渲染是一种用来描述用户界面的方式&#xff0c;它强调“声明”应该如何渲染页面&#xff0c;而不需要关心底层的DOM操作。这与传统的命令式渲染方式&#xff0c;即手动控制DOM元素的创建、更新和销毁&#xff0c;形成了鲜明的对比。 理解Vue的声明式渲染的关键…...

【已解决】Vue全局引入scss 个别页面不生效 / 不自动引入全局样式

项目里配置了全局样式的引入&#xff0c;今天新建了 demo 页面去修改 element 的样式&#xff0c;发现全局的样式没有引入进来。 问题原因 在此页面 没有任何样式导致的 项目在编译的时候&#xff0c;会把 .vue 文件的样式抽离到单独的 css 文件中。 当该页面没有css代码的时…...

MySQL之双主双从读写分离

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

使用eBPF加速阿里云服务网格ASM

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

【WiFi帧结构】

文章目录 帧结构MAC头部管理帧 帧结构 Wi-Fi的帧分为三部分组成&#xff1a;MAC头部frame bodyFCS&#xff0c;其中MAC是固定格式的&#xff0c;frame body是可变长度。 MAC头部有frame control&#xff0c;duration&#xff0c;address1&#xff0c;address2&#xff0c;addre…...

剑指offer20_链表中环的入口节点

链表中环的入口节点 给定一个链表&#xff0c;若其中包含环&#xff0c;则输出环的入口节点。 若其中不包含环&#xff0c;则输出null。 数据范围 节点 val 值取值范围 [ 1 , 1000 ] [1,1000] [1,1000]。 节点 val 值各不相同。 链表长度 [ 0 , 500 ] [0,500] [0,500]。 …...

在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?

uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件&#xff0c;用于在原生应用中加载 HTML 页面&#xff1a; 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...

虚拟电厂发展三大趋势:市场化、技术主导、车网互联

市场化&#xff1a;从政策驱动到多元盈利 政策全面赋能 2025年4月&#xff0c;国家发改委、能源局发布《关于加快推进虚拟电厂发展的指导意见》&#xff0c;首次明确虚拟电厂为“独立市场主体”&#xff0c;提出硬性目标&#xff1a;2027年全国调节能力≥2000万千瓦&#xff0…...

根目录0xa0属性对应的Ntfs!_SCB中的FileObject是什么时候被建立的----NTFS源代码分析--重要

根目录0xa0属性对应的Ntfs!_SCB中的FileObject是什么时候被建立的 第一部分&#xff1a; 0: kd> g Breakpoint 9 hit Ntfs!ReadIndexBuffer: f7173886 55 push ebp 0: kd> kc # 00 Ntfs!ReadIndexBuffer 01 Ntfs!FindFirstIndexEntry 02 Ntfs!NtfsUpda…...

Vue ③-生命周期 || 脚手架

生命周期 思考&#xff1a;什么时候可以发送初始化渲染请求&#xff1f;&#xff08;越早越好&#xff09; 什么时候可以开始操作dom&#xff1f;&#xff08;至少dom得渲染出来&#xff09; Vue生命周期&#xff1a; 一个Vue实例从 创建 到 销毁 的整个过程。 生命周期四个…...

【C++】纯虚函数类外可以写实现吗?

1. 答案 先说答案&#xff0c;可以。 2.代码测试 .h头文件 #include <iostream> #include <string>// 抽象基类 class AbstractBase { public:AbstractBase() default;virtual ~AbstractBase() default; // 默认析构函数public:virtual int PureVirtualFunct…...

高保真组件库:开关

一:制作关状态 拖入一个矩形作为关闭的底色:44 x 22,填充灰色CCCCCC,圆角23,边框宽度0,文本为”关“,右对齐,边距2,2,6,2,文本颜色白色FFFFFF。 拖拽一个椭圆,尺寸18 x 18,边框为0。3. 全选转为动态面板状态1命名为”关“。 二:制作开状态 复制关状态并命名为”开…...

21-Oracle 23 ai-Automatic SQL Plan Management(SPM)

小伙伴们&#xff0c;有没有迁移数据库完毕后或是突然某一天在同一个实例上同样的SQL&#xff0c; 性能不一样了、业务反馈卡顿、业务超时等各种匪夷所思的现状。 于是SPM定位开始&#xff0c;OCM考试中SPM必考。 其他的AWR、ASH、SQLHC、SQLT、SQL profile等换作下一个话题…...

HTML版英语学习系统

HTML版英语学习系统 这是一个完全免费、无需安装、功能完整的英语学习工具&#xff0c;使用HTML CSS JavaScript实现。 功能 文本朗读练习 - 输入英文文章&#xff0c;系统朗读帮助练习听力和发音&#xff0c;适合跟读练习&#xff0c;模仿学习&#xff1b;实时词典查询 - 双…...