var()的第二个参数是回退值,仅在变量完全未声明或声明为unset/initial时生效;若已声明为空字符串、非法值或无效语法,则不触发回退,且回退值中可嵌套var()实现多级降级。
很多人误以为 var(--color, red) 中的 red 是变量未定义时的“默认值”,其实它只是当 --color **完全未声明**(或声明为无效值,如 --color: ;)时才启用的兜底。一旦变量被声明(哪怕值非法),浏览器仍会尝试解析该值——此时回退值不会生效。
--color,或用 unset/initial 显式重置后读取--color: 123;、--color: #ffg;、--color: url( 等语法错误值——这些会导致计算值为 inherit 或继承值,而非跳转到回退var() 调用中起作用,不会影响其他属性或后续声明回退值支持完整 CSS 值语法,包括再次调用 var()。这能构建多层降级策略,比如主题色 fallback 链:
background-color: var(--bg-primary, var(--bg-base, #fff));
执行逻辑是:先查 --bg-primary,不存在/无效 → 查 --bg-base,还不存在/无效 → 用 #fff。但要注意:
var() 的回退值都独立求值,不会缓存中间结果var(--x, var(--x, ...))),会报 CSS parse error
这是最常踩的坑:CSS 变量允许声明空值,例如 --size: ; 或 --size: "",此时 var(--size, 16px) 仍返回空字符串,而非 16px。因为变量“已声明”,只是值无效。
立即学习“前端免费学习笔记(深入)”;
getComputedStyle(el).getPropertyValue('--size') 检查返回是否为 ""
el.style.setProperty('--size', size || '16px');
:root)中声明的空变量,也会让所有后代元素的 var() 绕过回退现代浏览器对 var() 回退的解析开销可忽略,且 var() 本身从 Chrome 49 / Firefox 31 / Safari 9.1 就已支持(IE 完全不支持)。真正要留意的是语义混淆:
transition、transform)中用复杂回退链,可能掩盖真实值缺失问题var(--pad, 1rem 2rem) 然后指望媒体查询自动切),必须靠 JS 或额外变量控制