0

0

css 常见盒模型错误有哪些_新手容易踩坑点汇总

P粉602998670

P粉602998670

发布时间:2025-12-31 06:27:20

|

785人浏览过

|

来源于php中文网

原创

<p>默认 box-sizing: content-box 导致 width 仅指内容区,加上 padding 和 border 后总宽为 242px;推荐全局设 * { box-sizing: border-box; } 统一预期。</p>

css 常见盒模型错误有哪些_新手容易踩坑点汇总

width 设了 200px,结果元素宽 242px?这是 content-box 的默认行为

新手最常懵的点:明明写了 width: 200px,加了 padding: 20pxborder: 1px solid,一测发现实际占位是 242px。这不是 bug,是 W3C 标准盒模型(box-sizing: content-box)的本意——width 只管内容区,padding 和 border 得额外加。

  • 总宽度 = width + 左右 padding + 左右 border + 左右 margin
  • height 同理,垂直方向也一样“偷偷加高”
  • 用 Chrome DevTools 的“Computed”面板点开盒模型图示,能立刻看到四层尺寸拆分

子元素 width: 100% + padding 导致父容器溢出滚动条

典型翻车场景:父容器设了 width: 100%,子元素也写 width: 100% 再加 padding: 15px,结果横向出现滚动条,布局错位。

  • 原因:content-box 下,100% 指父容器 content 宽度,padding 是额外加在它外面的
  • 解决不是靠“调小 width”,而是统一用 box-sizing: border-box
  • 推荐做法:全局重置,避免漏写
    * {
      box-sizing: border-box;
    }

两个 div 垂直挨着,margin-top 和 margin-bottom 却“合并”成一个值

这就是 margin collapsing(外边距折叠):相邻块级元素的垂直 margin 不叠加,而是取其中较大者。比如上元素 margin-bottom: 30px,下元素 margin-top: 20px,实际间距只有 30px,不是 50px。

  • 只发生在垂直方向(上下),左右 margin 不会折叠
  • 父子嵌套时也可能发生 margin 传递(子元素 top margin “顶穿”父容器)
  • 常见解法:overflow: hiddendisplay: flow-root 或给父容器加 border/padding

百分比 padding 居然按父容器宽度算高度?没错,这是规范

padding-top: 20%,结果发现高度随父容器宽度变化,而不是自身高度——这不是浏览器 bug,是 CSS 规范明确规定的:所有方向的百分比 paddingmargin(除 margin 的 left/right 在某些旧环境外)都基于父容器的 宽度 计算。

PathFinder
PathFinder

AI驱动的销售漏斗分析工具

下载

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

  • 想实现等比例缩放的正方形容器?可以利用这个特性:padding-top: 100% + height: 0 + 绝对定位子元素
  • 但别指望它响应自身 height 变化;若需真正按高度算,请改用 calc() 或 JS 动态设置
  • flex/grid 容器中该行为不变,但布局上下文可能掩盖问题

实际开发中,最省心的起点就是那行 * { box-sizing: border-box; }——它不改变逻辑,只把“宽度预期”和“代码所见”对齐。其余坑,基本都是忘了它,或没意识到 margin 和 padding 在盒模型里根本不是“装饰”,而是参与空间计算的硬性组成部分。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1060

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

841

2023.11.06

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1060

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

841

2023.11.06

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

531

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6255

2023.08.17

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.9万人学习

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

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