CSS 属性值计算过程(Computed Value)

CSS 属性值计算过程(Computed Value)

浏览器把你写的样式、默认样式、继承样式,一步步算出最终 Computed 值,决定元素长什么样。


一、总流程:4 步走完,所有属性必有值

markdown 复制代码
1. 确定声明值 → 2. 层叠(解决冲突) → 3. 继承 → 4. 使用默认值
步骤 作用 关键点
1. 确定声明值 收集所有样式声明 作者样式 + 浏览器默认样式,无冲突直接采用
2. 层叠 解决冲突,只留一个赢家 重要性 → 特殊性 → 源码顺序
3. 继承 补上前两步仍无值的属性 仅可继承属性(color、font-size 等),优先级低于声明
4. 使用默认值 兜底 走完前三步仍无值,用属性规范初始值

二、逐步骤精讲

1. 确定声明值

收集所有作用于当前元素的样式,并做基础转换:

操作 示例
颜色值转换 redrgb(255, 0, 0)
字重转换 bold700
规则修正 float: left 强制把 display 转为 block

2. 层叠(解决冲突 --- 核心)

冲突属性按 3 层优先级 筛选赢家:

① 比较重要性

yaml 复制代码
作者样式(有 !important) > 作者样式(无 !important) > 浏览器默认样式

② 比较特殊性(权重)

四位数规则:(内联, ID, 类/属性/伪类, 元素/伪元素),从高位比到低位

选择器 权重
内联 style="" 1, 0, 0, 0
#id 0, 1, 0, 0
.class / [attr] / :hover 0, 0, 1, 0
div / ::before 0, 0, 0, 1

③ 比较源码顺序

权重相同,后写覆盖先写

3. 继承

  • 只作用于前两步仍无值的属性
  • 只有可继承属性 才会拿父元素的值:color font-size line-height text-align
  • 继承优先级 < 声明 / 层叠

例:<a> 标签默认有 text-decoration,已在声明值阶段确定,不会继承 bodynone

4. 使用默认值

走完前三步仍无值 → 使用该属性规范的初始值(initial value),保证所有属性都有值、元素能正常渲染。


三、调试万能公式

样式不对 → 打开浏览器 DevTools → Computed 面板

  1. 看最终值是否符合预期
  2. 倒推:声明错?权重不够?没继承?被默认样式覆盖?

四、面试一句话总结

CSS 属性值计算分四步:收集声明 → 层叠解决冲突(重要性 > 权重 > 顺序)→ 继承父元素可继承属性 → 默认值兜底。所有属性最终必有值。

相关推荐
kyriewen6 小时前
微软用Go重写TypeScript编译器,速度提升10倍,网友:这是“背叛”还是“救赎”?
前端·typescript·ecmascript 6
Ceelog6 小时前
久坐党自救指南:屏幕前 8 小时,身体到底在经历什么
前端·后端
西陵7 小时前
Agent 为什么会陷入 Doom Loop?OpenClaw 的破解之道
前端·人工智能·ai编程
Hyyy7 小时前
普通前端续命周报——第2周
前端
wuxinyan1237 小时前
工业级大模型学习之路030:Streamlit 企业级智能体前端工作台
前端·学习·streamlit·智能体
修己xj8 小时前
告别无效刷屏!TrendRadar:最快30秒部署的开源热点助手,让你只看真正关心的新闻
前端
anOnion9 小时前
构建无障碍组件之Slider Pattern
前端·html·交互设计
云水一下9 小时前
JavaScript 从零基础到精通系列:前世今生与编程启蒙
前端·javascript
月亮邮递员6169 小时前
Markdown语法总结
开发语言·前端·javascript
Kurisu5759 小时前
雾锁王国修改器下载2026最新
前端·修改器代码