box-sizing属性可改变CSS盒模型计算方式,默认content-box下宽高仅含内容,padding和border额外增加总尺寸;使用border-box后,宽高包含内容、内边距和边框,使布局更直观可控。通过全局设置, ::before, *::after { box-sizing: border-box; }可统一所有元素的盒模型,避免布局错位,提升开发效率。
默认情况下,CSS 的盒模型将元素的宽度(width)和高度(height)仅应用于内容区域,而内边距(padding)、边框(border)和外边距(margin)会额外增加总尺寸。这在布局时容易导致计算复杂。box-sizing 属性可以改变这种计算方式,让开发者更直观地控制元素的实际大小。
这是浏览器默认的盒模型:
使用 border-box 后,元素的 width 和 height 包含了内容、内边距和边框:
height 是元素最终占据的总宽高为了简化页面布局,很多开发者会在全局重置 box-sizing:
*, *::before, *::after {
box-sizing: border-box;
}
这样所有元素都采用 border-box 模型,避免意外溢出或错位,尤其在栅格布局、弹性盒子中更加可控。
基本上就这些,合理使用 box-sizing 能大幅减少尺寸计算的困扰。