Float浮动

Float浮动

CSSfloat属性会使元素浮动,使元素向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。

实例

  • 元素的水平方向浮动,意味着元素只能左右移动而不能上下移动。
  • 使用float意味着使用块布局,其会在display非块级元素情况下修改display值的计算值。
  • 一个浮动元素会尽量向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。
  • 浮动元素会脱离文档流但不会脱离文本流,当浮动时其不会影响周围的盒子模型,但是文字会环绕在浮动元素周围,可以认为文档流与文字流是分层结构而浮动元素盒子与文字元素处于同一层。
  • 文档流,指的是盒子元素排版布局过程中,元素会自动从左往右,从上往下的流式排列。
  • 文本流,指的是文字元素排版布局过程中,元素会自动从左往右,从上往下的流式排列。
  • 脱离文档流,也就是将元素从普通的布局排版中拿走,其他盒子在定位的时候,会当做脱离文档流的元素不存在而进行定位。
<!DOCTYPE html>
<html>
<head><title>Float</title><style type="text/css">body > div{border: 1px solid #eee;padding: 5px 0;margin: 5px 0;}.t1{margin: 0 5px;float: left;background-color: #EEE;}</style>
</head>
<body><div><div class="t1">Float</div><div class="t1">Float</div><div class="t1">Float</div><div style="height: 10px;background-color: blue;"></div></div>
</body>
</html>

文字环绕效果

可以认为文档流与文字流是分层结构而浮动元素盒子与文字元素处于同一层,当元素浮动时,其脱离文档流不脱离文本流,所以浮动元素的渲染与文字的渲染是一并渲染的,浮动元素会将文字元素挤开,呈现文字环绕浮动元素的效果。

<!DOCTYPE html>
<html>
<head><title>Float</title><style type="text/css">body > div{border: 1px solid #eee;padding: 5px 0;margin: 5px 0;}.t1{margin: 0 5px;float: left;background-color: #EEE;height: 100px;width: 100px;}</style>
</head>
<body><div><div class="t1">Float</div><div>123</div><div>123</div><div>123</div><div>123</div><div>123</div><div>123</div><div>123</div></div>
</body>
</html>

虽然float最初的设计就是用来实现文字环绕效果的,在某些使用float的布局下若是不想触发文字环绕效果,可以通过触发BFC来避免文字环绕。

<!DOCTYPE html>
<html>
<head><title>Float</title><style type="text/css">body > div{border: 1px solid #eee;padding: 5px 0;margin: 5px 0;}.t1{margin: 0 5px;float: left;background-color: #EEE;height: 100px;width: 100px;}</style>
</head>
<body><div><div class="t1">Float</div><div style="overflow: auto;"><div>123</div><div>123</div><div>123</div><div>123</div><div>123</div><div>123</div><div>123</div></div></div>
</body>
</html>

清除浮动

使用浮动可能会导致一些负面影响,由于脱离文档流,无法撑起父元素导致背景以及边框无法正常显示、与其他元素重叠、下层浮动依旧会在上层浮动元素的基础上进行浮动等问题,此时就需要清除浮动。

使用clear属性

通过CSSclear: both;清除浮动。

<!DOCTYPE html>
<html>
<head><title>Float</title><style type="text/css">.container{border: 1px solid #eee;padding: 5px 0;margin: 5px 0;}.t1{margin: 0 5px;float: left;background-color: #EEE;height: 100px;width: 100px;}.clear{clear: both;}</style>
</head>
<body><div class="container"><div class="t1">Float</div><div class="t1">Float</div><div class="t1">Float</div><div style="height: 10px;background-color: blue;"></div><!-- 此处不清除浮动会产生负面效果 --></div><div class="container"><div class="t1">Float</div><div class="t1">Float</div><div class="t1">Float</div><div style="height: 10px;background-color: blue;"></div><!-- 清除浮动 --><div class="clear"></div></div><!-- 若是在此处清除浮动也是可以的 但是会无法撑起容器高度 --><div class="container"><div class="t1">Float</div><div class="t1">Float</div><div class="t1">Float</div><div style="height: 10px;background-color: blue;"></div><!-- 清除浮动 --><div class="clear"></div></div>
</body>
</html>

配合::after与clear属性

通过使用伪元素::after配合clear属性进行浮动清除。

<!DOCTYPE html>
<html>
<head><title>Float</title><style type="text/css">.container{border: 1px solid #eee;padding: 5px 0;margin: 5px 0;}.t1{margin: 0 5px;float: left;background-color: #EEE;height: 100px;width: 100px;}.container::after{clear: both;content:"";display: block;}</style>
</head>
<body><div class="container"><div class="t1">Float</div><div class="t1">Float</div><div class="t1">Float</div><div style="height: 10px;background-color: blue;"></div></div><div class="container"><div class="t1">Float</div><div class="t1">Float</div><div class="t1">Float</div><div style="height: 10px;background-color: blue;"></div></div></body>
</html>

触发BFC

触发浮动容器的BFC来清除浮动。

<!DOCTYPE html>
<html>
<head><title>Float</title><style type="text/css">.container{border: 1px solid #eee;padding: 5px 0;margin: 5px 0;overflow: auto; /* 触发BFC */}/* BFC 块级格式化上下文 https://github.com/WindrunnerMax/EveryDay/blob/master/CSS/%E5%9D%97%E7%BA%A7%E6%A0%BC%E5%BC%8F%E5%8C%96%E4%B8%8A%E4%B8%8B%E6%96%87.md */.t1{margin: 0 5px;float: left;background-color: #EEE;height: 100px;width: 100px;}</style>
</head>
<body><div class="container"><div class="t1">Float</div><div class="t1">Float</div><div class="t1">Float</div><div style="height: 10px;background-color: blue;"></div></div><div class="container"><div class="t1">Float</div><div class="t1">Float</div><div class="t1">Float</div><div style="height: 10px;background-color: blue;"></div></div></body>
</html>

每日一题

https://github.com/WindrunnerMax/EveryDay

参考

https://www.cnblogs.com/lingdu87/p/7770752.html
https://developer.mozilla.org/zh-CN/docs/CSS/float
https://www.w3school.com.cn/css/css_positioning_floating.asp

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

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

相关文章

基于springboot的酒店管理系统源码数据库

时代的发展带来了巨大的生活改变&#xff0c;很多事务从传统手工管理转变为自动管理。自动管理是利用科技的发展开发的新型管理系统&#xff0c;这类管理系统可以帮助人完成基本的繁琐的反复工作。酒店是出门的必需品&#xff0c;无论出差还是旅游都需要酒店的服务。由于在旺季…

Vue3中的常见组件通信之`$refs`、`$parent`

Vue3中的常见组件通信之$refs、$parent 概述 ​ 在vue3中常见的组件通信有props、mitt、v-model、 r e f s 、 refs、 refs、parent、provide、inject、pinia、slot等。不同的组件关系用不同的传递方式。常见的撘配形式如下表所示。 组件关系传递方式父传子1. props2. v-mod…

智能合约中代理漏洞

合约代理漏洞 代理模式在智能合约开发中非常常见&#xff0c;尤其是在升级和模块化设计中。代理合约&#xff08;Proxy Contract&#xff09;通常用于分离逻辑实现与合约的外部接口&#xff0c;允许在不改变接口的情况下升级或替换底层实现。然而&#xff0c;如果代理合约的初…

Vue数据动态代理机制的实现

Object.defineProperty() &#xff08;1&#xff09;这个方法是ES5新增的 &#xff08;2&#xff09;这个方法的作用是&#xff1a;给对象新增属性&#xff0c;或者设置对象原有的属性 &#xff08;3&#xff09;用法&#xff1a;Object.defineProperty(给哪个对象新增属性,‘…

深入解析:MySQL连接超时问题排查与优化策略

引言 ​ 在现代企业应用中&#xff0c;数据库的稳定性和响应速度是保证业务连续性的关键。MySQL作为广泛使用的数据库系统&#xff0c;其连接超时问题可能成为性能瓶颈&#xff0c;影响用户体验和业务效率。本文将深入探讨MySQL连接超时的原因、影响以及优化策略。 超时配置详…

【虚拟现实】一、AR与VR的基本原理

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 增强现实&#xff08;AR&#xff09;和虚拟现实&#xff08;VR&#xff09;技术已经从科幻小说走入现实&#xf…

UR机器人通信汇总

文章目录 一、概述二、UR机器人通信2.1UR通信协议2.2 UR通信端口 三、UR机器人通信端口类型3.1 Modbus TCP端口&#xff08;502端口&#xff09;3.2 Dashboard端口&#xff08;29999端口&#xff09;3.3 上位机编程端口&#xff08;30001/30002/30003端口&#xff09;3.3.1 URS…

linux本地搭建dns

不需要图形化界面 使用的是dnsmasq&#xff0c;配置简单 1.安装 deb系列linux apt-get install dnsmasqrhat系列linux yum install dnsmasq2.编辑配置文件 vi /etc/dnsmasq.conf设置主dns服务器&#xff0c;比如现有公用的的114.114.114.114 8.8.8.8这类的 server8.8.8.8…

MyBatis 延迟加载,一级缓存,二级缓存设置

MyBatis不仅提供了一级缓存和二级缓存机制&#xff0c;还支持延迟加载&#xff08;Lazy Loading&#xff09;&#xff0c;以进一步优化性能。 1. 延迟加载&#xff08;Lazy Loading&#xff09; 延迟加载是在需要时才加载数据&#xff0c;而不是在查询时立即加载所有相关数据。…

字节开源Hyper-SD模型,超越SDXL-Lightning,单步生成SOTA级图像

前言 近年来&#xff0c;扩散模型&#xff08;Diffusion Model&#xff0c;DM&#xff09;在图像生成领域取得了显著进展&#xff0c;展现出前所未有的图像质量和多样性。然而&#xff0c;扩散模型的训练和推理过程通常需要多个步骤&#xff0c;这限制了其在实际应用中的效率。…

注册小程序

每个小程序都需要在 app.js 中调用 App 方法注册小程序实例&#xff0c;绑定生命周期回调函数、错误监听和页面不存在监听函数等。 详细的参数含义和使用请参考 App 参考文档 。 整个小程序只有一个 App 实例&#xff0c;是全部页面共享的。开发者可以通过 getApp 方法获取到全…

172.二叉树:左叶子之和(力扣)

代码解决 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr, right(nullptr) {}* Tree…

代码随想录算法训练营第32天(py)| 贪心 | 122.买卖股票的最佳时机II、55. 跳跃游戏、45.跳跃游戏II

122.买卖股票的最佳时机II 力扣链接 给你一个整数数组 prices &#xff0c;其中 prices[i] 表示某支股票第 i 天的价格。 在每一天&#xff0c;你可以决定是否购买和/或出售股票。你在任何时候 最多 只能持有 一股 股票。你也可以先购买&#xff0c;然后在 同一天 出售。 返…

python学习 - 在线 百度语音API 播报 测试案例分析

在进行百度语音API的播报测试时&#xff0c;可以遵循以下步骤来确保测试的顺利进行。 1. 注册百度语音账号 访问百度语音开发平台&#xff1a;ai.baidu.com/tech/speech注册成为百度开发者&#xff0c;创建个人或企业账号 2. 创建应用并获取API密钥 在控制台中&#xff0c;…

RandomDate(接口参数化-随机生成日期)

目录 1、入口位置&#xff1a;2、验证函数生成值3、获取 年月日时分秒 的全随机4、时间函数 前言&#xff1a;有时候我们做性能测试或者接口测试时&#xff0c;参数需要传入日期格式&#xff0c;但是又不想每次都是用同一个日期&#xff0c;我们就可以使用Jmeter工具中函数助手…

2024050702-重学 Java 设计模式《实战状态模式》

重学 Java 设计模式&#xff1a;实战状态模式「模拟系统营销活动&#xff0c;状态流程审核发布上线场景」 一、前言 写好代码三个关键点 如果把写代码想象成家里的软装&#xff0c;你肯定会想到家里需要有一个非常不错格局最好是南北通透的&#xff0c;买回来的家具最好是品…

Mysql 中的case-when

什么是 case-when case-when 是一种 sql 语句中的语法结构,结构如下&#xff1a; case 字段名 when 值 then 字段名|值 ... else 字段名|值 end case when 主要用于数据的 行列转换&#xff08;把一列数据转换为多列&#xff09; 前置条件&#xff1a; -- 表…

02.体验CSS以及Bootstrap框架

目录 CSS固定格式 1&#xff09;style标签 2&#xff09;div标签 3&#xff09;span标签 CSS属性 一、文字属性 1.规范文字样式的属性 2.规定文字粗细的属性 3.规定文字大小的属性 4.规范文字字体的属性 二、文本属性 1.文本装饰属性 2.文本水平对齐属性 3.文本缩进…

[flutter]一键将YAPI生成的api.json文件转为需要的Dart Model类的脚本

目的&#xff1a; 根据YAPI接口平台生成的api.json接口文件&#xff0c;将接口数据转化为model类&#xff0c;生成对应的接口值类型文件。 发现&#xff1a; api.json文件导出&#xff1a; YAPi是一个接口管理平台&#xff0c;登录账号打开项目后&#xff0c;在点击数据管理…

Vuex3学习笔记

文章目录 1&#xff0c;入门案例辅助函数 2&#xff0c;mutations传参辅助函数 3&#xff0c;actions辅助函数 4&#xff0c;getters辅助函数 5&#xff0c;模块拆分6&#xff0c;访问子模块的state辅助函数 7&#xff0c;访问子模块的getters辅助函数 8&#xff0c;访问子模块…