浮动布局虽被Flex/Grid取代,但在老项目、IE8+兼容及布局演进理解中仍需掌握;核心是清除浮动、脱离文档流与高度塌陷;两栏用float+margin,三栏有圣杯与双飞翼;推荐clearfix清除浮动;新项目应优先使用Flex或Grid。
浮动布局虽已逐渐被 Flex 和 Grid 取代,但在老项目维护、兼容性要求高(如 IE8+)或理解 CSS 布局演进逻辑时,仍需掌握其核心实现思路。关键不在“怎么写”,而在“为什么这样写”——尤其是清除浮动、文档流脱离、高度塌陷这些易错点。
典型场景:左侧导航栏 200px,右侧主内容区占满剩余宽度。
核心逻辑:左侧元素 float: left 脱离文档流,右侧内容通过 margin-left 预留空间,避免文字环绕。
+ 中间自适应经典圣杯布局(Holy Grail)和双飞翼布局(Double Flying Wings)都基于浮动,区别在于 HTML 结构与负 margin 的运用方式。
圣杯布局特点:中间内容 DOM 在前,利于 SEO 和首屏渲染;靠 padding + 负 margin 挤出侧栏位置。
浮动导致父容器高度为 0 是最常见问题,必须显式处理。
—— 不推荐,污染结构浮动本质是为图文环绕设计的,用作页面整体布局属于“hack”。它难以处理垂直居中、等高列、响应式重排等问题。
实际开发中建议: