HTML — 浮动

浮动

     HTML浮动(Float)是一种CSS布局技术,通过float: left或float: right使元素脱离常规文档流并向左/右对齐,常用于图文混排或横向排列内容。浮动元素会紧贴父容器或相邻浮动元素的边缘,但脱离文档流后可能导致父容器高度塌陷,需通过伪元素添加clear: both来修复。传统布局中,浮动被用于多栏设计或导航菜单,但因需手动计算宽度且适配性差,逐渐被Flexbox和Grid布局替代。使用浮动时需注意元素间的间距控制,避免内容重叠;现代开发中建议优先选择更直观的弹性或网格布局,仅保留浮动用于简单的文本环绕场景,如图片与文字的自然排版。


浮动的核心特性

     通过元素脱离文档流,实现水平对齐,常见于图文混排或多元素横向排列。浮动元素紧贴父容器或相邻元素边缘,但会导致父容器高度塌陷,需用clear: both清除浮动。

离文档流

HTML脱离文档流指元素(如float、fixed定位)不再占据常规布局空间,父容器可能高度塌陷,后续元素会填补其位置,需手动调整布局或清除浮动避免错位,常见于悬浮层、弹窗等场景。

<div class="float-box"></div>
<p>文字内容将围绕浮动元素排列...</p><style>
.float-box {float: left;width: 150px;height: 150px;background: skyblue;margin-right: 20px;
}
</style>

此代码效果:蓝色方块浮动后,段落文字自动环绕

元素自动转为块级元素

HTML元素通过设置display:block或特定属性(如float、position:absolute/fixed)转为块级,独占一行且可设置宽高,如默认块级元素<div>或行内元素<span>被强制转换后的表现。

span {float: left;  /* 行内元素变为块级 */width: 200px; /* 原本无效的属性生效 */
}

经典布局

HTML经典布局依赖表格、浮动或定位实现,但代码响应式适配差,需手动计算尺寸,现逐渐被Flex/Grid布局取代,适用于传统网页适配场景。

两栏布局

两栏布局是页面被分成左右两个主要区域。一个常见的例子是左侧为导航栏,右侧为主要内容区。

 如图所示,这就是一个经典的两栏布局

<div class="box"><div class="left">左栏</div><div class="right">右栏</div>
</div><style>
.left {float: left;width: 200px;background: #ffe4b5;
}
.right {float: right;width: 150px;background: #98fb98;
}
</style>

此代码就是一个正常的两栏布局框架

三栏布局

三栏布局增加了中间的内容区,两边可以作为侧边栏使用。这种布局适合内容较多且需要分类展示的网页。

  如图所示,这就是一个经典的三栏布局,HTML元素按照它们在HTML文档中的顺序从上到下、从左到右依次排列的方式。每个块级元素默认占据一整行,而内联元素则在同一行内连续排列直到没有足够的空间为止。通过改变元素的display、position等属性,我们可以调整元素的位置和排列方式,但这些操作都是基于标准文档流进行的。

<div class="box"><div class="left">左栏</div><div class="right">右栏</div><div class="main">主内容区</div>
</div><style>
.left {float: left;width: 200px;background: #ffe4b5;
}
.right {float: right;width: 150px;background: #98fb98;
}
.main {margin: 0 160px 0 210px; /* 间距设置 */
}
</style>

此代码就是一个正常的三栏布局框架


display 属性

display属性定义元素的显示模式,控制元素排列方式及子元素布局规则,例如display: none可隐藏元素。

display属性用于定义元素生成的框的类型:

block元素前后换行显示,宽度默认占满父容器。

inline元素不换行显示,只占用其内容所需的空间。

inline-block元素不会独占一行,但是它可以设置高度和宽度。

none元素不生成任何框,即该元素不会显示。


float 属性

float属性它主要用于图像环绕文本效果或创建多列布局如:使元素向左/右浮动,脱离文档流,实现图文混排或横向布局;需用clear清除浮动避免父容器高度塌陷。

left元素向左浮动。

right元素向右浮动。

none默认值,元素不会浮动

.image-left {float: left;
}
.image-right {float: right;
}

clear 属性

HTML的clear属性用于清除元素两侧的浮动影响,防止被浮动元素环绕,通常加在需恢复文档流的元素上,如clear: both解决父容器高度塌陷,适配传统浮动布局场景。

clear属性用于阻止父元素内的子元素环绕浮动元素。

left不允许元素左边有浮动元素。

right不允许元素右边有浮动元素。

both不允许元素左右两边都有浮动元素。

none默认值,允许元素四周有浮动元素。


清除浮动

HTML清除浮动解决父容器高度塌陷,常用方法:添加空元素clear:both,父级overflow:hidden现代布局推荐Flex/Grid替代浮动。

清除

在浮动元素后面添加一个空的<div>标签,并设置clear:both 。

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

 BFC触发

为父容器设置overflow: hidden

.box {border: 3px solid #48dbfb;margin-bottom: 30px;padding: 10px;overflow: hidden; /* 关键代码:触发BFC */
}

浮动与现代布局对比

特性FloatFlexboxGrid
布局维度一维一维二维
响应式支持需要媒体查询内置弹性内置响应
内容流控制破坏文档流保持文档流保持文档流
浏览器兼容性全支持IE10+IE11+

总结 

     HTML浮动(Float)是CSS早期核心布局技术,通过float: left/right使元素脱离文档流并向指定方向对齐,常用于实现图文混排(如图片文字环绕)或多栏布局。浮动元素会紧贴父容器或相邻浮动元素边缘,但脱离文档流的特性会导致父容器高度塌陷(不包含浮动元素高度),需通过以下方式解决:  

  1. 清除浮动:在父容器末尾添加clear: both的空元素;  
  2. BFC触发:为父容器设置overflow: hidden;  

浮动布局需手动计算宽度且响应式适配困难,现代开发中更推荐FlexboxGrid布局替代,仅保留简单场景(如文本环绕图片)使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/78791.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【软件测试学习day1】软件测试概念

前言 本篇学习&#xff0c;测试相关基础概念、常见的开发模型测和测试模型&#xff0c;搞懂4个问题&#xff1a; 什么是需求什么是 bug什么是测试用例开发模型和测试模型 目录 1. 什么是需求 1.1 为什么要有需求 1.2 测试人员眼里的需求 1.3 如何深入了解需求 2. 测试用例…

Flutter常用组件实践

Flutter常用组件实践 1、MaterialApp 和 Center(组件居中)2、Scaffold3、Container(容器)4、BoxDecoration(装饰器)5、Column(纵向布局)及Icon(图标)6、Column/Row(横向/横向布局)+CloseButton/BackButton/IconButton(简单按钮)7、Expanded和Flexible8、Stack和Po…

刘火良FreeRTOS内核实现与应用学习之7——任务延时列表

在《刘火良FreeRTOS内核实现与应用学习之6——多优先级》的基础上&#xff1a;关键是添加了全局变量&#xff1a;xNextTaskUnblockTime &#xff0c;与延时列表&#xff08;xDelayedTaskList1、xDelayedTaskList2&#xff09;来高效率的实现延时。 以前需要在扫描就绪列表中所…

图像预处理-插值方法

一.插值方法 当我们对图像进行缩放或旋转等操作时&#xff0c;需要在新的像素位置上计算出对应的像素值。 而插值算法的作用就是根据已知的像素值来推测未知位置的像素值。 1.1 最近邻插值 CV2.INTER_NEAREST 其为 warpAffine() 函数的参数 flags 的其一&#xff0c;表示最近…

智能配电保护:公共建筑安全的新 “防火墙”

安科瑞刘鸿鹏 摘要 随着城市建筑体量的不断增长和电气设备的广泛使用&#xff0c;现代建筑大楼的用电安全问题日益突出。传统配电方式面临监测盲区多、响应滞后、火灾隐患难发现等问题。为提升建筑电气系统的安全性和智能化水平&#xff0c;智慧用电系统应运而生。本文结合安…

如何解决DDoS攻击问题 ?—专业解决方案深度分析

本文深入解析DDoS攻击面临的挑战与解决策略&#xff0c;提供了一系列防御技术和实践建议&#xff0c;帮助企业加强其网络安全架构&#xff0c;有效防御DDoS攻击。从攻击的识别、防范措施到应急响应&#xff0c;为网络安全工作者提供了详细的操作指引。 DDoS攻击概览&#xff1a…

构建灵活的接口抽象层:支持多种后端数据存取的实战指南

构建灵活的接口抽象层:支持多种后端数据存取的实战指南 引言 在现代软件开发中,数据存取成为业务逻辑的核心组成部分。然而,由于后端数据存储方式的多样性(如关系型数据库、NoSQL数据库和文件存储),如何设计一套能够适配多种后端数据存取的接口抽象层,成为技术团队关注…

OpenCV 图形API(23)图像和通道合成

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 1.算法描述 在OpenCV的G-API模块中&#xff0c;图像和通道合成&#xff08;composition&#xff09;函数允许用户对图像进行复杂的操作&#xff0c;如合并…

帝国cms导航淘客新闻下载多功能网站源码 二次元风格自适应附教程

一、本模板使用帝国cms7.5 utf8版本&#xff0c;二次元导航新闻下载工具淘客自适应响应式帝国cms模板。 1、网站后台有3个系统模型&#xff0c;新闻系统模型&#xff0c;下载系统模型&#xff0c;导航系统模型&#xff0c;商城系统模型&#xff0c;可以根据自己的需求不同&…

本地部署大模型(ollama模式)

分享记录一下本地部署大模型步骤。 大模型应用部署可以选择 ollama 或者 LM Studio。本文介绍ollama本地部署 ollama官网为&#xff1a;https://ollama.com/ 进入官网&#xff0c;下载ollama。 ollama是一个模型管理工具和平台&#xff0c;它提供了很多国内外常见的模型&…

C# virtual 和 abstract 详解

简介 在 C# 中&#xff0c;virtual 和 abstract 关键字都用于面向对象编程中的继承和多态&#xff0c;它们主要用于方法、属性和事件的定义&#xff0c;但在用法上存在一些重要的区别。 virtual 关键字 virtual 表示可重写的方法&#xff0c;但可以提供默认实现&#xff0c;…

自动驾驶的数据集以及yolov8和yolop

项目背景 网络全部是分割了没有检测。 自动驾驶的车道线和可行驶区域在数据集中的表示 自动驾驶系统中的车道线和可行驶区域的表示方式主要有以下几种&#xff1a; 基于几何模型&#xff1a;使用几何模型来描述车道线和可行驶区域的形状和位置&#xff0c;例如直线、曲线、多…

Oracle DROP、TRUNCATE 和 DELETE 原理

在 Oracle 11g 中&#xff0c;DROP、TRUNCATE 和 DELETE 是三种不同的数据清理操作&#xff0c;它们的底层原理和适用场景有显著差异 1. DELETE 的原理 类型&#xff1a;DML&#xff08;数据操作语言&#xff09; 功能&#xff1a;逐行删除表中符合条件的数据&#xff0c;保留…

PCIe 5.0光学SSD原型问世!

近日&#xff0c;Kioxia Corporation&#xff08;铠侠&#xff09;、AIO Core Co., Ltd. 和 Kyocera Corporation&#xff08;京瓷&#xff09;联合宣布成功开发了一款支持 PCIe 5.0 接口的光学 SSD 原型。该技术旨在通过光接口替换传统的电接口&#xff0c;从而显著增加计算设…

SQL 查询中涉及的表及其作用说明

SQL 查询中涉及的表及其作用说明&#xff1a; 涉及的数据库表 表名别名/用途关联关系dbo.s_orderSO&#xff08;主表&#xff09;存储订单主信息&#xff08;订单号、日期、客户等&#xff09;dbo.s_orderdetailSoD&#xff08;订单明细&#xff09;通过 billid SO.billid 关…

C++学习之金融类安全传输平台项目git

目录 1.知识点概述 2.版本控制工具作用 3.git和SVN 4.git介绍 5.git安装 6.工作区 暂存区 版本库概念 7.本地文件添加到暂存区和提交到版本库 8.文件的修改和还原 9.查看提交的历史版本信息 10.版本差异比较 11.删除文件 12.本地版本管理设置忽略目录 13.远程git仓…

【HCIP】GRE VPN实验笔记

一、实验拓扑 二、实验要求 1、按照图示配置IP地址 2、在R1和R3上配置默认路由使公网区域互通 3、在R1和R3上配置GRE VPN&#xff0c;使两端私网能够互相访问&#xff0c;Tunnel口IP地址如图 4、在R1和R3上配置RIPv2或者ospf或者静态&#xff0c;来传递两端私网路由 三、实…

大模型——Llama Stack快速入门 部署构建AI大模型指南

Llama Stack快速入门 部署构建AI大模型指南 介绍 Llama Stack 是一组标准化和有主见的接口,用于如何构建规范的工具链组件(微调、合成数据生成)和代理应用程序。我们希望这些接口能够在整个生态系统中得到采用,这将有助于更轻松地实现互操作性。 Llama Stack 定义并标准化…

ALOPS智能化运维管理平台

AIOps&#xff08;Artificial Intelligence for IT Operations&#xff09;即智能运维&#xff0c;是将人工智能技术应用于 IT 运维管理领域&#xff0c;以实现自动化、智能化的运维决策和管理。以下是关于 AIOps 的详细介绍&#xff1a; 核心能力 数据收集与整合&#xff1a…

C语言超详细指针知识(二)

在上一篇有关指针的博客中&#xff0c;我们介绍了指针的基础知识&#xff0c;如&#xff1a;内存与地址&#xff0c;解引用操作符&#xff0c;野指针等&#xff0c;今天我们将更加深入的学习指针的其他知识。 1.指针的使用和传址调用 1.1strlen的模拟实现 库函数strlen的功能是…