CSS盒模型是什么?box-sizing有什么作用?

一、CSS 盒模型(Box Model)是什么?

在 CSS 中,每一个元素都可以看成一个矩形盒子

这个盒子由 4 个部分组成:

复制代码
┌─────────────────────────┐
│        margin           │  ← 外边距
│  ┌───────────────────┐  │
│  │      border       │  │  ← 边框
│  │  ┌─────────────┐  │  │
│  │  │   padding   │  │  │  ← 内边距
│  │  │  ┌────────┐ │  │  │
│  │  │  │ content│ │  │  │  ← 内容区域
│  │  │  └────────┘ │  │  │
│  │  └─────────────┘  │  │
│  └───────────────────┘  │
└─────────────────────────┘

盒模型结构从内到外:

复制代码
content → padding → border → margin

二、标准盒模型(默认)

默认情况下,浏览器使用的是:

复制代码
box-sizing: content-box;

📌 计算方式

复制代码
div {
  width: 200px;
  padding: 20px;
  border: 10px solid black;
}

实际宽度 =

复制代码
200 (content)
+ 40 (左右padding)
+ 20 (左右border)
= 260px

⚠️ 注意:width 只算 content,不包含 padding 和 border。


三、IE 盒模型 / 现代推荐写法

复制代码
box-sizing: border-box;

📌 计算方式

复制代码
div {
  width: 200px;
  padding: 20px;
  border: 10px solid black;
  box-sizing: border-box;
}

实际宽度 = 200px

浏览器会自动计算:

复制代码
content = 200 - padding - border

也就是说:

复制代码
content = 200 - 40 - 20 = 140px

👉 width 包含 content + padding + border


四、box-sizing 有什么作用?

一句话总结:

决定 width / height 到底是计算 content 还是整个盒子


对比总结

属性 content-box border-box
默认值 ✅ 是 ❌ 否
width 是否包含 padding ❌ 不包含 ✅ 包含
width 是否包含 border ❌ 不包含 ✅ 包含
布局是否容易计算 ❌ 容易撑破 ✅ 更稳定

五、为什么实际开发都用 border-box?

在你做后台管理系统(Ant Design 表格布局)或移动端页面时,如果用 content-box,很容易出现:

  • 宽度 100%

  • 再加 padding

  • 结果元素超出父容器

举例:

复制代码
.card {
  width: 100%;
  padding: 20px;
}

如果是 content-box:

👉 实际宽度 = 100% + 40px

直接撑爆父元素

而 border-box:

👉 永远不会超出 100%


六、实际项目最佳实践

几乎所有现代项目都会这样写:

复制代码
* {
  box-sizing: border-box;
}

或者更完整一点:

复制代码
*, *::before, *::after {
  box-sizing: border-box;
}

这样整个项目都统一用 border-box。

React / Vue / Ant Design 其实默认也都是这种思路。


七、面试加分点(进阶理解)

1️⃣ margin 不参与 width 计算

margin 是外部空间,不属于盒子本身。


2️⃣ padding 会影响背景色

背景色会覆盖:

复制代码
content + padding

但不会覆盖 margin。


3️⃣ 行内元素的盒模型

  • 行内元素不能设置 width / height

  • padding、margin 水平方向有效

  • 垂直方向表现特殊

相关推荐
@不误正业几秒前
2026-05-16-多Agent协作框架深度实战-从ReAct到Plan-and-Execute全架构演进
前端·react.js·架构
我命由我12345几秒前
PHP - PHP 简易 Web 服务器、基础接口开发
服务器·开发语言·前端·php·intellij-idea·idea·intellij idea
咖喱o2 分钟前
IPv6
服务器·前端·网络
海上彼尚3 分钟前
Nodejs也能写Agent - 6.基础篇 - Agent
前端·人工智能·后端·node.js
2501_940041747 分钟前
纯前端实战:5个高复杂度业务与交互场景
前端
renke336411 分钟前
写给前端的 CANN-torchtitan-npu:昇腾PyTorch Titan适配到底是啥?
前端·人工智能·pytorch·cann
lihaozecq13 分钟前
Agent 开发的 skills 机制设计 - 渐进式披露
前端·agent·ai编程
安生生申17 分钟前
uni-app 连接 JDY-31 蓝牙串口模块实践
c语言·前端·javascript·stm32·单片机·嵌入式硬件·uni-app
Restart-AHTCM21 分钟前
LangChain学习之模型 I/O 与输出解析器 (Output Parsers)(3/8)
前端·学习·langchain
lqj_本人22 分钟前
鸿蒙PC:electron-markdownify 从普通 Electron 迁移到 OpenHarmony Electron HAP 的完整实践
前端·javascript·electron