默认 box-sizing: content-box 导致 width 仅指内容区,加上 padding 和 border 后总宽为 242px;推荐全局设 * { box-sizing: border-box; } 统一预期。
新手最常懵的点:明明写了 width: 200px,加了 padding: 20px 和 border: 1px solid,一测发现实际占位是 242px。这不是 bug,是 W3C 标准盒模型(box-sizing: content-box)的本意——width 只管内容区,padding 和 border 得额外加。
width + 左右 padding + 左右 border + 左右 margin
典型翻车场景:父容器设了 width: 100%,子元素也写 width: 100% 再加 padding: 15px,结果横向出现滚动条,布局错位。
100% 指父容器 content 宽度,padding 是额外加在它外面的box-sizing: border-box
* {
box-sizing: border-box;
}这就是 margin collapsing(外边距折叠):相邻块级元素的垂直 margin 不叠加,而是取其中较大者。比如上元素 margin-bottom: 30px,下元素 margin-top: 20px,实际间距
只有 30px,不是 50px。
overflow: hidden、display: flow-root 或给父容器加 border/padding
写 padding-top: 20%,结果发现高度随父容器宽度变化,而不是自身高度——这不是浏览器 bug,是 CSS 规范明确规定的:所有方向的百分比 padding 和 margin(除 margin 的 left/right 在某些旧环境外)都基于父容器的 宽度 计算。
padding-top: 100% + height: 0 + 绝对定位子元素calc() 或 JS 动态设置实际开发中,最省心的起点就是那行 * { box-sizing: border-box; }——它不改变逻辑,只把“宽度预期”和“代码所见”对齐。其余坑,基本都是忘了它,或没意识到 margin 和 padding 在盒模型里根本不是“装饰”,而是参与空间计算的硬性组成部分。