深入解析浮动布局及其在现代Web开发中的应用与替代(浮动的概念及应用、如何清除浮动、使用Flex布局和Grid布局的区别、使用`float`布局的历史和现状)
文章目录
- 1. 引言
- 2. 浮动的概念及应用
- 3. 如何清除浮动
- 4. 使用Flex布局和Grid布局的区别
- 5. 使用`float`布局的历史和现状
- 6. 综合案例展示
- 7. 结论
- 8. 建议
1. 引言
在CSS布局的历史中,float属性曾是网页布局的主要工具之一。然而,随着现代布局技术(如Flexbox和Grid)的兴起,float布局逐渐被替代。本博客将探讨float的概念、应用、清除浮动的方式,以及现代布局技术Flex和Grid的区别,并讨论float布局的历史和现状。
2. 浮动的概念及应用
CSS中的float属性用于将元素从正常的文档流中取出,使其向左或向右浮动,同时文本和内联元素会环绕在浮动元素的旁边。
float值 | 作用 |
|---|---|
left | 将元素向左浮动,其他内容围绕在元素的右边。 |
right | 将元素向右浮动,其他内容围绕在元素的左边。 |
none | 默认值,元素不浮动。 |
示例:简单的float布局
<div class="box" style="float: left;">左浮动</div>
<p>其他内容将会环绕在浮动元素旁边。</p>
浮动曾用于实现两列或多列布局,以及图文混排的效果。通过浮动左侧或右侧的元素,可以让文本围绕图片或其他内容。
3. 如何清除浮动
在使用浮动布局时,父元素往往无法自动包裹浮动的子元素,导致布局错乱。为了解决这个问题,必须清除浮动,常见的方法有以下几种:
-
使用
clear属性:直接在后续元素上应用clear,阻止浮动影响。<div class="clear" style="clear: both;"></div>clear: both;表示元素不允许位于任何浮动元素的左右。clear: left;表示不允许位于左浮动元素的左侧。clear: right;表示不允许位于右浮动元素的右侧。
-
父元素设置
overflow: hidden;:强制父容器包裹浮动元素。<div class="container" style="overflow: hidden;"><div class="box" style="float: left;">左浮动</div> </div> -
使用伪元素清除浮动:在父元素上使用
::after伪元素,常见的“清除浮动”类如下:.clearfix::after {content: "";display: table;clear: both; }
4. 使用Flex布局和Grid布局的区别
随着Flexbox和Grid布局的引入,开发者有了更加灵活和直观的布局工具。它们在许多情况下取代了float布局。
| 布局方式 | 定义及应用场景 | 布局特点 |
|---|---|---|
| Flexbox | 一维布局系统,主要用于行或列中的元素排列。常用于创建水平或垂直居中的布局。 | 适合处理单行或单列布局,灵活性强,支持弹性空间分配和对齐。 |
| Grid布局 | 二维布局系统,适合处理复杂的网格布局,可同时处理行和列。 | 适合多维网格布局,允许元素跨行、跨列,布局能力更强大。 |
Flex布局示例:
<div class="container"><div class="item">Item 1</div><div class="item">Item 2</div>
</div><style>.container {display: flex;justify-content: space-between;}.item {width: 45%;}
</style>
Grid布局示例:
<div class="grid-container"><div class="item">Item 1</div><div class="item">Item 2</div>
</div><style>.grid-container {display: grid;grid-template-columns: repeat(2, 1fr);}
</style>
- Flex适用于内容动态变化的场景,例如弹性盒子布局。
- Grid适用于静态网格布局,布局更加明确且有控制力。
5. 使用float布局的历史和现状
-
历史:
float属性最早用于实现文本环绕图片的效果。然而,随着网页设计需求的增加,开发者开始使用float实现多列布局,甚至整个页面的布局。尽管这不是float的设计初衷,但在没有更好的布局工具时,它成为了主流选择。- 早期网页布局常常用到
float来创建复杂的两列或三列布局,并配合清除浮动的技巧来保持页面的整洁。
- 早期网页布局常常用到
-
现状:随着
Flexbox和Grid布局的出现,float逐渐退出了主要布局工具的舞台。现代网页设计倾向于使用更语义化和灵活的布局工具,如Flexbox来处理一维布局,Grid来处理复杂的二维布局。
6. 综合案例展示
下面是一个示例,通过float实现两列布局并清除浮动,同时展示如何使用Flexbox替代该布局:
浮动布局:
<div class="container"><div class="left" style="float: left; width: 45%;">左侧内容</div><div class="right" style="float: right; width: 45%;">右侧内容</div><div class="clear" style="clear: both;"></div>
</div>
Flex布局:
<div class="container" style="display: flex; justify-content: space-between;"><div class="left" style="width: 45%;">左侧内容</div><div class="right" style="width: 45%;">右侧内容</div>
</div>
在这个案例中,Flexbox更简单直接,并且不需要处理浮动和清除浮动的问题。
7. 结论
虽然float在CSS布局的早期占据了重要位置,但随着Flexbox和Grid的出现,现代开发者已经有了更加适合和强大的工具来处理网页布局。尽管如此,理解float的原理及其应用仍然对前端开发者来说非常重要,尤其是在处理老旧代码或特殊布局需求时。
8. 建议
- 使用
float时要清楚它的局限性,尤其在现代布局中尽量避免。 - 优先使用
Flexbox和Grid来处理复杂布局,以简化代码和提升布局灵活性。 - 在处理旧项目或兼容性问题时,仍需掌握
float的清除技巧。
相关文章:
深入解析浮动布局及其在现代Web开发中的应用与替代(浮动的概念及应用、如何清除浮动、使用Flex布局和Grid布局的区别、使用`float`布局的历史和现状)
文章目录 1. 引言2. 浮动的概念及应用3. 如何清除浮动4. 使用Flex布局和Grid布局的区别5. 使用float布局的历史和现状6. 综合案例展示7. 结论8. 建议 1. 引言 在CSS布局的历史中,float属性曾是网页布局的主要工具之一。然而,随着现代布局技术࿰…...
WPF基础权限系统
一.开发环境 VisualStudio 2022NET SDK 8.0Prism 版本 8.1.97Sqlite 二. 功能介绍 WPF 基础权限系统,是一个支持前后端分离设计的 客户端(C/S)项目,该示例项目前端xaml使用UI库 ,Material Design Themes UI 来构建用户界面,确保…...
【Java函数篇】Java 8 Predicate函数接口的用法详解
为什么介绍Predicate 自从Java8发布以后,代码里面就多了很多函数式的接口和代码。在流式的编程中,我们经常会用到Predicate和其他函数,在一些开源的代码中也会看到别人定义的Predicate方法。但其实你有没有感觉在写代码的经历中,…...
C++ 一个反射的例子
在 C 中实现反射机制,虽然不像其他高级语言那样直接,但可以通过宏、模板和注册系统等技术来实现一个简易的反射系统。下面是一个完整的 C 反射机制示例,通过自定义类注册系统和宏定义,实现类的名称、属性、方法的反射 。 #includ…...
vue3 解决背景图与窗口留有间隙的问题
需要实现一个登录界面,login.vue的代码如下: <script> import { ref } from vue;export default {setup() {return {};}, }; </script><template><div id"login-container" class"login-container"><di…...
Cesium for UE-04-一些说明
目前主要做webgis的工作,UE官方对web的支持截止到了4.23版本,即使是4.23版本之后的4.xx版本也有办法支持,已经有大佬开源了一些方法和工具,不再介绍。即使是4.23想要输出为h5,也是有一定的折腾门槛的。最重要的是【Ces…...
AIGC:开启智能创造的璀璨新篇章
在当今科技迅猛发展的时代浪潮中,人工智能( Artificial Intelligence , AI )已然历经了从早期的计算智能、感知智能逐步迈向认知智能的辉煌历程。而在这一进程中, AI 生成内容( Artificial Intelligence Generated Con…...
计算机组成原理与系统结构——外部存储器
笔记内容及图片整理自XJTUSE “计算机组成原理与系统结构” 课程ppt,仅供学习交流使用,谢谢。 磁盘 磁盘是一个由非磁性材料构成的圆形盘片(称为基片),上面涂抹可磁化材料。传统的基片一直是铝制或铝合金的࿰…...
如何使用 Browserless 抓取动态网站?
什么是动态网页? 动态网页是指其内容并非完全直接嵌入在静态HTML中,而是通过服务器端或客户端渲染生成的网页。 它可以根据用户的操作实时显示数据,例如在用户点击按钮或向下滚动页面时加载更多内容(如无限滚动)。这…...
第21~22周Java主流框架入门-Spring 2.SpringAOP面向切面编程
1.Spring AOP (Aspect-Oriented Programming) 1. 1. 什么是 Spring AOP? AOP(面向切面编程) 是 Spring 提供的一种可插拔的组件技术,允许我们在软件运行过程中添加额外的功能。场景:假设有两个模块,用户管…...
Flutter不常用组件----InteractiveViewer
在现代移动应用开发中,用户互动性是提升体验的关键。Flutter 提供了多种组件来帮助开发者实现丰富的交互功能,其中一个强大的组件便是 InteractiveViewer。它允许用户通过手势对内容进行缩放、平移和旋转,适用于需要用户查看大图、地图或者其…...
【LeetCode HOT 100】详细题解之二分查找篇
【LeetCode HOT 100】详细题解之二分查找篇 35 搜索插入位置思路代码(左闭右闭)代码(左闭右开) 74 搜索二维矩阵思路代码(左闭右闭) 34 在排序数组中查找元素的第一个和最后一个位置思路代码 33 搜索旋转排序数组思路代码 153 寻找旋转排序数组中的最小值思路代码 4 寻找两个正…...
管理篇(顶级思维模型(31个))(待做)
目录 一、成长进阶模型 二、优势探索模型 三、优势层次模型 四、人生定位模型 五、看懂人性模型 六、如何抉择模型 七、本质思考模型 八、心流模型 九、精力管理模型 十、高效沟通模型 十一、100%传递模型 十二、高效倾听模型 十三、高效表达模型 十四、精准提问模…...
十一、数据库配置
一、Navicat配置 这个软件需要破解 密码是:123456; 新建连接》新建数据库 创建一个表 保存出现名字设置 双击打开 把id设置为自动递增 这里就相当于每一次向数据库添加一个语句,会自动增长id一次 二、数据库的增删改查 1、Vs 建一个控…...
day02 -- docker
1.docker的介绍 Docker 是一个开源的应用容器引擎,基于 Go语言 并遵从 Apache2.0 协议开源。Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使…...
ecmascript标准
1. 简介 1.1. 概述 ECMAScript(简称ES)是JavaScript编程语言的一个标准化版本。它是为网络开发设计的一种轻量级的脚本语言,主要用于在网页上实现交互性和动态效果。ECMAScript是该语言的标准名称,而JavaScript是其最知名和广泛使用的实现。 1.2. 特点 跨平台性 :ECMAS…...
在Linux命令行中一行执行多个命令
原文地址链接: https://kashima19960.github.io/2024/10/22/Linux/在Linux命令行中一行执行多个命令/,一般有最新的修改都是在我的个人博客里面,所以在当前平台的更新会比较慢,请见谅😃 前言 在shell中一个一个命令行,…...
u盘快速格式化后怎么恢复文件:深入解析与全面指南
U盘,凭借其小巧便携、易于使用的特点,成为了我们日常生活中不可或缺的数据存储工具。然而,有时为了清除病毒、解决文件系统错误或准备存储新数据,我们可能需要对U盘进行快速格式化。但这一操作往往伴随着一个严峻的问题࿱…...
青少年编程能力等级测评CPA C++(二级)试卷(2)
青少年编程能力等级测评CPA C(二级)试卷(2) 一、单项选择题(共20题,每题3.5分,共70分) CP2_2_1.下列C程序段中,对二维数组arr的定义不正确是( &…...
aws 把vpc残留删除干净
最近忘了把vpc 删干净导致又被收了冤大头钱 在删除vpc 的收发现又eni在使用,但是忘了是哪个资源在占用 先用命令行把占用的资源找出来停掉 使用 AWS 命令行界面(CLI)来查看 VPC 的使用情况 列出子网: aws ec2 describe-subnets …...
《Qt C++ 与 OpenCV:解锁视频播放程序设计的奥秘》
引言:探索视频播放程序设计之旅 在当今数字化时代,多媒体应用已渗透到我们生活的方方面面,从日常的视频娱乐到专业的视频监控、视频会议系统,视频播放程序作为多媒体应用的核心组成部分,扮演着至关重要的角色。无论是在个人电脑、移动设备还是智能电视等平台上,用户都期望…...
从深圳崛起的“机器之眼”:赴港乐动机器人的万亿赛道赶考路
进入2025年以来,尽管围绕人形机器人、具身智能等机器人赛道的质疑声不断,但全球市场热度依然高涨,入局者持续增加。 以国内市场为例,天眼查专业版数据显示,截至5月底,我国现存在业、存续状态的机器人相关企…...
大语言模型(LLM)中的KV缓存压缩与动态稀疏注意力机制设计
随着大语言模型(LLM)参数规模的增长,推理阶段的内存占用和计算复杂度成为核心挑战。传统注意力机制的计算复杂度随序列长度呈二次方增长,而KV缓存的内存消耗可能高达数十GB(例如Llama2-7B处理100K token时需50GB内存&a…...
力扣-35.搜索插入位置
题目描述 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 class Solution {public int searchInsert(int[] nums, …...
在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?
uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件,用于在原生应用中加载 HTML 页面: 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...
Fabric V2.5 通用溯源系统——增加图片上传与下载功能
fabric-trace项目在发布一年后,部署量已突破1000次,为支持更多场景,现新增支持图片信息上链,本文对图片上传、下载功能代码进行梳理,包含智能合约、后端、前端部分。 一、智能合约修改 为了增加图片信息上链溯源,需要对底层数据结构进行修改,在此对智能合约中的农产品数…...
AI+无人机如何守护濒危物种?YOLOv8实现95%精准识别
【导读】 野生动物监测在理解和保护生态系统中发挥着至关重要的作用。然而,传统的野生动物观察方法往往耗时耗力、成本高昂且范围有限。无人机的出现为野生动物监测提供了有前景的替代方案,能够实现大范围覆盖并远程采集数据。尽管具备这些优势…...
从面试角度回答Android中ContentProvider启动原理
Android中ContentProvider原理的面试角度解析,分为已启动和未启动两种场景: 一、ContentProvider已启动的情况 1. 核心流程 触发条件:当其他组件(如Activity、Service)通过ContentR…...
协议转换利器,profinet转ethercat网关的两大派系,各有千秋
随着工业以太网的发展,其高效、便捷、协议开放、易于冗余等诸多优点,被越来越多的工业现场所采用。西门子SIMATIC S7-1200/1500系列PLC集成有Profinet接口,具有实时性、开放性,使用TCP/IP和IT标准,符合基于工业以太网的…...
9-Oracle 23 ai Vector Search 特性 知识准备
很多小伙伴是不是参加了 免费认证课程(限时至2025/5/15) Oracle AI Vector Search 1Z0-184-25考试,都顺利拿到certified了没。 各行各业的AI 大模型的到来,传统的数据库中的SQL还能不能打,结构化和非结构的话数据如何和…...
