0

0

css标准盒模型与替代盒模型_box-sizing的使用区别

P粉602998670

P粉602998670

发布时间:2026-01-16 12:59:30

|

415人浏览过

|

来源于php中文网

原创

box-sizing: content-box 是默认盒模型,width/height 仅控制内容区,padding 和 border 额外增加;border-box 则将 width/height 视为总尺寸,padding 和 border 向内压缩内容区;全局重置为 border-box 可统一行为、降低调试成本。

css标准盒模型与替代盒模型_box-sizing的使用区别

box-sizing: content-box 是什么行为?

这是所有现代浏览器的默认盒模型,widthheight 只管内容区(content)大小,内边距和边框会“额外加出去”。比如设了 width: 200px; padding: 10px; border: 3px solid;,元素实际占位宽度就是 200 + 10×2 + 3×2 = 226px

  • 适合需要严格控制内容区域尺寸的场景(如等宽文字容器)
  • 但每次改 paddingborder 都得手动重算总宽,容易布局错位
  • 响应式中配合 % 宽度时,paddingborder 会让子元素撑出父容器

box-sizing: border-box 是怎么“省事”的?

border-box 把你写的 widthheight 当作最终可见框的尺寸——内边距和边框从这个尺寸里“往里扣”,内容区自动收缩。上面那个例子设成 box-sizing: border-box; 后,总宽稳稳就是 200px,内容区只剩 200 − 20 − 6 = 174px 宽。

  • 写栅格、卡片、表单控件时几乎必用,避免反复调整尺寸
  • flex / grid 配合更自然,子项不会因 padding 溢出
  • IE8+ 全支持,移动端无兼容问题

为什么全局重置推荐 * { box-sizing: border-box; }?

因为不加这条,每个新写的块级元素(divsectionheader 等)都默认走 content-box,等于埋下布局隐患。用通配符统一切换后,所有元素行为一致,调试成本大幅下降。

PicWish
PicWish

推荐!专业的AI抠图修图,支持格式转化

下载
  • 注意:该规则不影响 svginput[type="button"] 等部分原生控件的默认行为,个别需单独覆盖
  • 若项目已存在大量 content-box 逻辑,切勿贸然全局重置,先用 CSS 自定义属性或 scoped class 局部迁移
  • 真正要警惕的是嵌套使用:父元素 border-box,子元素又显式设 content-box,容易导致尺寸预期断裂

什么时候必须保留 content-box?

极少,但真实存在:比如封装一个「纯内容容器」组件,要求其 width 必须严格等于内部文本渲染宽度(不含任何装饰),或者对接某些依赖标准模型的第三方 UI 库(如旧版 Bootstrap 3 的某些 grid 类)。

立即学习前端免费学习笔记(深入)”;

  • 不要为了“遵循规范”而坚持 content-box,W3C 早已将 border-box 列为正式特性
  • 如果只是想模拟传统表格单元格的伸缩行为,用 table-cell 显示模式比硬套 content-box 更可靠
  • 最常被忽略的一点:margin 在两种模型中都不参与 width/height 计算——但它会影响兄弟元素间距,这点永远不变

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

522

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

262

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

753

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

539

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

757

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

604

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

560

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

391

2023.08.22

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

5

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 19.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号