CSS元素的总宽度计算规则

CSS 盒子模型(Box Model)的默认计算规则

在默认情况下(box-sizing: content-box),元素的总宽度计算公式是:总宽度 = 内容区宽度(width) + 左右内边距(padding-left + padding-right) + 左右边框(border-left + border-right)

这种计算方式的设计逻辑是:

  • width 仅表示元素内部内容区域的宽度
  • padding 是内容与边框之间的空间,属于元素 "内部扩展"
  • border 是元素的边框线,属于元素 "边缘"

比如:

javascript 复制代码
div {
  width: 240px;
  height: 35px;
  border: 1px solid #d9e0ee;
  border-top: 3px solid #ff8400;
  line-height: 35px;
  padding-left: 40px;
  font-size: 14px;
}

当设置 width: 240px 并添加 padding-left: 40pxborder: 1px 时:总宽度 = 240px(内容) + 40px(左内边距) + 0(右内边距) + 1px(左边框) + 1px(右边框) = 282px

【注】padding-left 会让元素整体变宽 ------ 因为默认规则下,内边距和边框都是在 width 之外额外计算的。

增加 padding-left 时,元素的总宽度会变大(内容宽 + 左内边距 + 边框宽度)。

要解决这个问题,可以使用 box-sizing: border-box 属性,它会让 width 包含内容区、内边距和边框的宽度,这样修改 padding 就不会改变元素的总宽度了。

添加 box-sizing: border-box 后:

  • 元素的总宽度会固定为 width 设定的 240px
  • padding-left: 40px 会从内容区域内部 "挤压" 空间,而不是向外扩展
  • 边框的宽度也会包含在总宽度内,不会额外增加元素的整体尺寸
javascript 复制代码
div {
  width: 240px;
  height: 35px;
  border: 1px solid #d9e0ee;
  border-top: 3px solid #ff8400;
  line-height: 35px;
  padding-left: 40px;
  font-size: 14px;
  /* 新增这行代码 */
  box-sizing: border-box;
}
相关推荐
0思必得012 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东51613 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino13 小时前
图片、文件的预览
前端·javascript
layman052815 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔15 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李15 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN15 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒15 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库15 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
电商API_1800790524715 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫