news 2026/6/15 13:29:00

(九)浮动的性质(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/6/14 17:04:28

Dify 1.7.0音频切片配置秘籍,快速上手不容错过的7个步骤

第一章&#xff1a;Dify 1.7.0音频切片配置概述 Dify 1.7.0 版本引入了对音频处理能力的增强支持&#xff0c;特别是在多模态应用中&#xff0c;音频切片功能成为连接语音识别与大语言模型的关键环节。通过合理的音频切片配置&#xff0c;系统能够在保证语义完整性的前提下&…

作者头像 李华
网站建设 2026/6/14 14:30:46

Dify平台批量OCR项目落地难点剖析(Tesseract高并发处理实战经验)

第一章&#xff1a;Dify平台批量OCR项目落地背景与挑战在数字化转型加速的背景下&#xff0c;企业对非结构化文档的自动化处理需求日益增长。Dify平台作为一款支持AI工作流编排的低代码开发工具&#xff0c;被选为构建批量OCR&#xff08;光学字符识别&#xff09;系统的首选方…

作者头像 李华
网站建设 2026/6/15 2:31:42

为什么你的Dify备份总是失效?资深架构师剖析5大常见陷阱

第一章&#xff1a;为什么你的Dify备份总是失效&#xff1f;资深架构师剖析5大常见陷阱在构建和维护基于 Dify 的 AI 应用平台时&#xff0c;数据备份是保障系统稳定与可恢复性的核心环节。然而&#xff0c;许多团队即便配置了定期备份策略&#xff0c;仍频繁遭遇恢复失败、数据…

作者头像 李华
网站建设 2026/6/8 11:29:48

【资深架构师亲授】:Dify中加密PDF解析错误的7种典型场景与应对方案

第一章&#xff1a;加密 PDF 解析的 Dify 错误处理 在使用 Dify 平台处理文档解析任务时&#xff0c;加密的 PDF 文件常引发异常中断。这类文件因安全策略限制内容读取&#xff0c;导致解析流程失败并抛出权限错误。为保障系统稳定性&#xff0c;需在预处理阶段识别加密状态并实…

作者头像 李华
网站建设 2026/6/13 12:30:06

WTAPI个人微信机器人API

在微信深度渗透私域运营与客户服务的背景下&#xff0c;开发个人微信机器人需解决“如何与微信交互”“如何调用聊天接口”“如何稳定获取微信数据”等核心问题。用户常见的技术方案包括微信Web接口、Xposed/PC Hook、模拟机技术及iPad扫码协议&#xff0c;而WTAPI作为基于iPad…

作者头像 李华