news 2026/5/11 15:52:51

(九)浮动的性质(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/5/10 19:41:26

Dify分支跳转实战指南(90%开发者忽略的关键细节)

第一章&#xff1a;Dify工作流分支跳转的核心概念Dify 工作流的分支跳转机制是实现复杂自动化逻辑的关键能力&#xff0c;它允许流程根据运行时条件动态选择执行路径。通过定义明确的判断规则和目标节点&#xff0c;开发者可以构建出具备决策能力的智能应用流程&#xff0c;从而…

作者头像 李华
网站建设 2026/5/8 3:24:10

AnythingLLM Windows安装指南及注意事项

AnythingLLM Windows 安装与配置实战指南 在本地部署一个能理解你所有文档的 AI 助手&#xff0c;听起来像是未来科技&#xff1f;其实今天就能实现。随着 Llama3、Phi-3 等高效开源模型的成熟&#xff0c;像 AnythingLLM 这类集成了 RAG&#xff08;检索增强生成&#xff09;…

作者头像 李华
网站建设 2026/5/8 2:25:49

飞桨Paddle安装配置与Python入门指南

飞桨Paddle安装配置与Python入门指南 在AI开发的世界里&#xff0c;一个稳定、高效的深度学习框架是项目成功的关键。对于中文开发者而言&#xff0c;飞桨&#xff08;PaddlePaddle&#xff09; 不仅是一个技术选择&#xff0c;更是一种“母语级”的开发体验——从文档到模型库…

作者头像 李华
网站建设 2026/5/8 17:45:25

LobeChat能否预测用户行为?数据洞察新视角

LobeChat&#xff1a;打开用户行为洞察之门的AI交互平台 在AI助手几乎无处不在的今天&#xff0c;我们早已习惯了向Siri提问天气、让Copilot生成代码。但你有没有想过——这些对话背后&#xff0c;系统是否真的“理解”你在想什么&#xff1f;或者说&#xff0c;它能不能预判你…

作者头像 李华
网站建设 2026/5/9 1:30:07

【私有化Dify SSL配置终极指南】:手把手教你实现安全通信与证书部署

第一章&#xff1a;私有化 Dify SSL 配置概述在企业级部署 Dify 时&#xff0c;启用 SSL 加密是保障数据传输安全的关键步骤。私有化部署环境中&#xff0c;通常需要通过自定义域名与受信证书实现 HTTPS 访问&#xff0c;以满足内部合规性与外部访问的安全要求。配置 SSL 不仅能…

作者头像 李华
网站建设 2026/5/9 0:34:31

LobeChat能否用于生成SEO标题?搜索引擎优化利器

LobeChat能否用于生成SEO标题&#xff1f;搜索引擎优化利器 在内容为王的时代&#xff0c;一个好标题的价值不言而喻——它不仅是用户点击的第一动因&#xff0c;更是搜索引擎判定内容相关性的关键信号。然而&#xff0c;面对每天需要产出多篇文章的运营团队&#xff0c;人工构…

作者头像 李华