news 2026/4/3 4:30:13

(九)浮动的性质(1)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(九)浮动的性质(1)

1、浮动的元素脱标

标准流元素是区分行、块。
我们知道了浮动元素是脱离标准流的,那么脱离标准流后,浮动元素有哪些特性?
答:浮动元素,脱离标准流后,既可以设置宽度和高度,也可以实现并排显示,不区分元素状态,也就是不区分行内元素和块级元素。

<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible"content="IE=edge"><meta name="viewport"content="width=device-width, initial-scale=1.0"><title>Document</title><style>*{margin:0;padding:0;}div{width:200px;height:200px;border:1px solid red;}div p{width:100px;height:100px;background:purple;}div span{width:100px;height:100px;background:orange;}</style></head><body><div><p>我是p标签</p><span>span标签</span></div></body>

p标签和span标签都设置了宽度和高度,但是由于元素类型的限制,span标签没有宽度和高度。

div内部元素浮动之后

div p{width:100px;height:100px;background:purple;float:left;}div span{width:100px;height:100px;background:orange;float:left;}


需要注意的是,兄弟元素如果有一个浮动了,剩下必须都要浮动。
如果此时p标签和span标签都没有设置宽度和高度,元素的宽度会被内容撑宽,不会自动撑满父盒子。

div p{background:purple;float:left;}div span{background:orange;float:left;}

2、依次贴边

如果父盒子的宽度不足以存下所有的子盒子,存放不下的会自动向前寻找,直到空余位置能够存放,从而进行贴边显示。

<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible"content="IE=edge"><meta name="viewport"content="width=device-width, initial-scale=1.0"><title>Document</title><style>*{margin:0;padding:0;}div{width:400px;height:400px;border:5px solid red;margin:100pxauto;}div p{width:100px;height:100px;float:left;}div p.par1{height:250px;background:green;}div p.par2{height:200px;background:blue;}div p.par3{background:yellow;}div p.par4{width:300px;background:cyan;}</style></head><body><div><pclass="par1">1</p><pclass="par2">2</p><pclass="par3">3</p><pclass="par4">4</p></div></body>


如果父盒子的宽度不够,子盒子会依次贴边,但是如果前面元素中有空隙,当前需要贴边的元素不会钻空,不会出现钻空的现象,而之会查询剩余宽度实现依次贴边。

<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible"content="IE=edge"><meta name="viewport"content="width=device-width, initial-scale=1.0"><title>Document</title><style>*{margin:0;padding:0;}div{width:600px;height:400px;border:5px solid red;margin:100pxauto;}div p{width:100px;height:100px;float:left;}div p.par1{height:250px;background:green;}div p.par2{width:330px;background:blue;}div p.par3{height:200px;background:yellow;}div p.par4{width:300px;background:cyan;}</style></head><body><div><pclass="par1">1</p><pclass="par2">2</p><pclass="par3">3</p><pclass="par4">4</p></div></body>


如果某一个子盒子的宽度大于了父盒子,会有溢出状态。

<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible"content="IE=edge"><meta name="viewport"content="width=device-width, initial-scale=1.0"><title>Document</title><style>*{margin:0;padding:0;}div{width:600px;height:400px;border:5px solid red;margin:100pxauto;}div p{width:100px;height:100px;float:left;}div p.par1{height:250px;background:green;}div p.par2{width:330px;background:blue;}div p.par3{height:200px;background:yellow;}div p.par4{width:650px;background:cyan;}</style></head><body><div><pclass="par1">1</p><pclass="par2">2</p><pclass="par3">3</p><pclass="par4">4</p></div></body>


向右贴边的原理和向左相同,也是按照先后顺序进行贴边。

<style>*{margin:0;padding:0;}div{width:600px;height:400px;border:5px solid red;margin:100pxauto;}div p{width:100px;height:100px;float:right;}div p.par1{height:250px;background:green;}div p.par2{width:100px;background:blue;}div p.par3{height:200px;background:yellow;}div p.par4{width:100px;background:cyan;}</style></head><body><div><pclass="par1">1</p><pclass="par2">2</p><pclass="par3">3</p><pclass="par4">4</p></div></body>

3、浮动依次贴边练习

<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible"content="IE=edge"><meta name="viewport"content="width=device-width, initial-scale=1.0"><title>Document</title><style>*{margin:0;padding:0;}.outer{height:440px;width:940px;padding:10px;border:2px solid #000;margin:10pxauto;}.outer div{float:left;}.outer.box1{height:260px;width:300px;background:pink;}.outer.box2{height:260px;width:240px;background:cyan;}.outer.s_box{height:130px;width:200px;}.outer.box3{background:yellowgreen;}.outer.box4{background:greenyellow;}.outer.box7{height:180px;width:300px;background:blueviolet;}.outer.s_box2{height:180px;width:160px;}.outer.box5{background:purple;}.outer.box6{background:palegreen;}</style></head><body><divclass="outer"><divclass="box1"></div><divclass="box2"></div><divclass="s_box box3"></div><divclass="s_box box4"></div><divclass="s_box box4"></div><divclass="s_box box3"></div><divclass="box7"></div><divclass="s_box2 box5"></div><divclass="s_box2 box6"></div><divclass="s_box2 box5"></div><divclass="s_box2 box6"></div></div></body></html>

4、浮动margin塌陷问题

标准流有margin塌陷的现象。
标准流:

浮动流:

总结:浮动元素没有了标准流的margin塌陷现象,各自有各自的margin,不会相互塌陷;

5、浮动元素让出标准流

标准流中的元素都有自己的一个标准流位置,后面的元素只能在前面元素的后面进行加载。
浮动元素脱离了标准流,它会让后面的元素占有自己原来的位置,显示效果上来看仿佛是自己“飘”起来了,我们称之为脱标了。

标准流显示

此时粉色盒子浮动了

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/26 17:02:31

如何在Docker中无缝传递Vercel AI SDK环境变量?3步实现自动化安全注入

第一章&#xff1a;Docker 与 Vercel AI SDK 的环境变量在现代全栈应用开发中&#xff0c;Docker 与 Vercel AI SDK 的结合为开发者提供了高效、可移植的部署方案。环境变量作为连接本地开发与云端服务的关键桥梁&#xff0c;必须被正确配置以确保应用的安全性与灵活性。环境变…

作者头像 李华
网站建设 2026/4/1 9:27:14

临床研究者必看,R语言填补缺失值的3大黄金法则与避坑指南

第一章&#xff1a;临床研究中缺失值的挑战与R语言应对策略在临床研究数据中&#xff0c;缺失值是常见且棘手的问题&#xff0c;可能源于患者失访、记录遗漏或检测失败。忽略缺失值可能导致偏倚估计和统计效力下降。R语言提供了系统化的工具来识别、可视化并处理缺失数据&#…

作者头像 李华
网站建设 2026/4/2 8:53:46

你还在全量加载?R Shiny动态模块加载的5个关键场景与避坑指南

第一章&#xff1a;你还在全量加载&#xff1f;R Shiny动态模块加载的5个关键场景与避坑指南在构建复杂的R Shiny应用时&#xff0c;全量加载所有UI和服务器逻辑会导致启动缓慢、内存占用高以及用户体验下降。通过动态模块加载&#xff0c;可以按需加载组件&#xff0c;显著提升…

作者头像 李华
网站建设 2026/3/31 6:35:40

高可用架构设计:LobeChat集群部署与负载均衡

高可用架构设计&#xff1a;LobeChat集群部署与负载均衡 在AI助手从个人玩具走向企业级应用的今天&#xff0c;一个看似简单的聊天界面背后&#xff0c;往往隐藏着复杂的系统工程挑战。想象这样一个场景&#xff1a;公司全员同时打开内部AI知识库提问&#xff0c;系统却因请求激…

作者头像 李华
网站建设 2026/3/30 19:21:32

提示工程架构师视角:Agentic AI的未来展望

提示工程架构师视角:Agentic AI的未来展望 一、引入:从“被动响应”到“主动服务”——AI的下一个进化拐点 凌晨11点,你揉着太阳穴关掉电脑——明天要去三亚出差,可还没订酒店、查天气,更没收拾行李。你对着手机说:“帮我处理三亚的行程。” 传统AI助手会机械地问:“…

作者头像 李华