元素间距不一致的根源是浏览器默认margin/padding差异或手动设置不统一,解决需“主动归零+统一设置”:重置默认值(通配符或normalize.css)、用语义化工具类管理间距、规避margin合并、响应式分层设计。
元素间距不一致,通常是因为不同标签默认的 margin 或 padding 值不同,或开发者手动设置了不统一的值。解决核心是“主动归零 + 统一设置”,而不是依赖浏览器默认行为。
浏览器对 h1~h6、p、ul、ol、form 等元素自带上下 margin,这是间距混乱的常见原因。
* { margin: 0; padding: 0; }(简单粗暴,适合小项目)h2, p, ul { margin-top: 0; margin-bottom: 1rem; }
避免在每个元素上写 margin-bottom: 20px 这类重复代码,改用语义化 class 管理。
.mb-s { margin-bottom: 0.5rem; }
.mb-m { mar
gin-bottom: 1rem; }
.mb-l { margin-bottom: 1.5rem; }
标题
正文段落
相邻块级元素的垂直 margin 会自动合并为较大的那个值,导致实际间距 ≠ 预期值。
元素分别设了 margin-bottom: 20px 和 margin-top: 12px,实际间距是 20px,不是 32pxmargin-bottom,顶部不留空)padding 替代部分 margin(父容器加 padding 更可控)overflow: hidden),阻止合并(慎用,影响布局)PC 和移动端对“合适间距”的感知不同,不能一套值打天下。
.mb-m { margin-bottom: 1rem; }
@media (max-width: 768px) { .mb-m { margin-bottom: 0.75rem; } }
:root { --space-base: clamp(0.5rem, 2vw, 1rem); }
.mb-auto { margin-bottom: var(--space-base); }