

新闻资讯
技术学院最常见的原因是 padding 被加在 width: 100% 之外,因默认 box-sizing: content-box 导致总宽度 = width + padding + border;修复方法是设 box-sizing: border-box 或全局重置 * { box-sizing: border-box; }。
设置 width: 100% 却溢出,最常见的原因就是 padding(内边距)被加在了 100% 宽度之外——这源于 CSS 默认的 box-sizing: content-box 盒模型。
在 content-box 模式下:
元素总宽度 = width + left padding + right padding + left border + right border
所以即使你写了 width: 100%,只要存在 padding 或 border,实际占用空间就会超过父容器宽度,导致水平溢出(尤其在响应式布局或 flex 容器中容易触发滚动条或错位)。
这是最直接、推荐的解决方案:
box-sizing:
border-box;
width: 100% 表示「包含 padding 和 border 在内的总宽度」,不会溢出* { box-sizing: border-box; }(含伪元素可加 ::before, ::after)即使你自己没写 padding,也要排查:
padding?子元素 width: 100% 是相对于父内容区计算的,但若父有 padding,子元素可能撑到父边框外(尤其当父设了 overflow: hidden 时更易发现)、、 常自带 padding)除了 padding,这些也常被忽略:
margin:虽然不影响 width 计算,但负 margin 或外边距合并可能导致视觉溢出white-space: nowrap + 长文本:强制不换行会突破容器宽度flex-shrink: 0:在空间不足时仍可能被压缩后因 padding 显得“挤出”img { width: auto; max-width: none; })