0

0

CSS如何理解box-sizing的继承性_通常建议在根元素设置并通过*继承

P粉602998670

P粉602998670

发布时间:2026-03-16 12:07:01

|

203人浏览过

|

来源于php中文网

原创

<p>box-sizing 不继承,html 上设置无效;必须用 { box-sizing: border-box; } 并配合 ::before, ::after(IE8 用 :before)才能全局生效,且需注意 shadow DOM、命名空间及旧项目兼容性。</p>

css如何理解box-sizing的继承性_通常建议在根元素设置并通过*继承

box-sizing 不会从父元素继承,html 上设了也没用

很多人以为在 html 元素上写 box-sizing: border-box,子元素就能自动继承——其实不会。box-sizing 是一个**不继承属性**(non-inherited property),哪怕你给 htmlbody 设了,所有子元素默认值仍是 content-box

常见错误现象:
– 页面里写了 html { box-sizing: border-box; },但 divinput 依然按 content-box 计算宽高
– 调试时发现元素尺寸“莫名变大”,其实是边框/内边距额外加进去了

  • 真正生效的写法是:用通配符强制重置所有元素,即 * { box-sizing: border-box; }
  • 必须搭配 *::before, *::after,否则伪元素仍走默认 content-box(它们也受该规则影响)
  • 注意:IE8+ 支持 box-sizing,但 IE8 不支持 *::before 写法,得写成 *:before(单冒号)

* { box-sizing: border-box } 的实际作用范围和边界

这个规则看似简单,但它的“覆盖力”有明确限制:

  • 它只作用于**匹配到的元素**,比如 svgmath 等命名空间内的元素不会被 * 匹配(除非显式声明)
  • 某些内置表单控件(如 input[type="range"] 在 Chrome 中的滑块轨道)可能忽略该设置,因为浏览器用 shadow DOM 渲染,外部样式无法穿透
  • 使用 Web Components 时,* 不会进入自定义元素的 shadow root,需在内部单独设置
  • 性能上几乎无影响——现代浏览器对 * 的优化已很成熟,别被老资料吓住

为什么不能只靠 inherit 手动继承?

有人想绕过通配符,改用 box-sizing: inherit 让子元素“主动继承”父级值。这理论上可行,但实操中极易断裂:

Machine Translation
Machine Translation

聚合多个来源的AI翻译

下载

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

  • 只要中间某层元素没显式设 box-sizing(比如某个第三方组件的 wrapper),继承链就断了,下游全退回 content-box
  • inherit 只继承计算后的值,而 box-sizing 没有“计算”过程,它就是字面值;一旦父级是默认值(content-box),子级继承的还是 content-box,起不到统一效果
  • 很多 CSS 重置库(如 Normalize.css)根本没碰 box-sizing,你手动加 inherit 会跟它们冲突或被覆盖

兼容旧项目时,* { box-sizing: border-box } 的安全落地方式

老项目突然加这条规则,常导致布局错位——不是规则不对,而是原有代码已按 content-box 做了尺寸预设。

  • 先用 DevTools 的“Computed”面板批量检查关键容器的 box-sizing 实际值,确认哪些地方已被第三方库(如 Bootstrap、Ant Design)覆盖
  • 如果用了 CSS-in-JS(如 Emotion、styled-components),确保全局注入在最顶层,且没被局部 !important 覆盖
  • 极少数情况需保留 content-box(比如依赖精确 content 宽高的 canvas 容器),可用 html.no-boxsize * { box-sizing: content-box !important; } 局部关闭
  • 别忘了测试打印样式(@media print),有些打印 CSS 会重置 box-sizing,导致纸张溢出

真正麻烦的从来不是怎么写这一行 CSS,而是你不知道哪段遗留代码正偷偷依赖着 content-box 的行为。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

1079

2023.08.11

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

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

849

2023.11.06

python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

193

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

19

2026.02.03

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字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

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

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

6331

2023.08.17

C++多线程并发控制与线程安全设计实践
C++多线程并发控制与线程安全设计实践

本专题围绕 C++ 在高性能系统开发中的并发控制技术展开,系统讲解多线程编程模型与线程安全设计方法。内容包括互斥锁、读写锁、条件变量、原子操作以及线程池实现机制,同时结合实际案例分析并发竞争、死锁避免与性能优化策略。通过实践讲解,帮助开发者掌握构建稳定高效并发系统的关键技术。

2

2026.03.16

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43.5万人学习

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

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