直接改 font-size 不如用 CSS 变量统一控制 rem 基准,因变量可联动更新 padding、line-height 等;必须在 :root 中绑定 font-size: var(--font-base) 且变量带单位;媒体查询应仅修改 :root 下变量;clamp() 中变量须为完整带单位值,避免混用单位与嵌套 calc 失效。
直接在 :root 里写 font-size: 16px 确实能控制 rem 基准,但一旦需要联动调整 padding、line-height、border-radius,就得挨个重写——而 CSS 变量只需改一处,所有引用它的属性自动响应。
常见错误是只定义变量却不绑定到根字体上:写了 --font-base: 16px,却没在 :root 里写 font-size: var(--font-base),结果 1rem 还是浏览器默认的 16px,变量形同虚设。
--font-base: 1rem 或 --font-base: 16px),不能只写数字font-size: var(--font-base) 必须显式写在 :root 规则里,否则不生效em 计算 padding,它不会随 rem 基准缩放,得额外覆盖别在每个断点里重复写 font-size,而是统一在 :root 里定义变量,再用媒体查询重设值。这样所有引用 var(--fs-h2) 的地方都会同步更新。
典型错误是把变量定义在局部选择器里(比如 .card { --fs-h2: 1.5rem; }),然后在 @media 中试图修改 :root 下的同名变量——根本无效,作用域不匹配。
立即学习“前端免费学习笔记(深入)”;
:root,确保全局可访问:root { --fs-h2: 1.75rem; } 修改,不能写成 .card { --fs-h2: ... }
!important 覆盖变量值,否则后续媒体查询无法再覆盖--fs-h2,它会回退到移动端初始值,不是“延续上一个断点”clamp() 本身支持变量,但变量值必须是完整带单位的长度(如 1.25rem),不能是纯数字加单位拼接。浏览器不解析 calc(var(--a) * 1vw) 这类嵌套,也不接受 var(--fs-min) 是 1.125(缺单位)。
混用单位是高频翻车点:写 clamp(1rem, 4vw, 24px) 看似合理,但 1rem 和 24px 基准不同,小屏下可能因换算抖动;iOS Safari 对含 vh 的 clamp() 支持不稳定,优先用 vw。
--fs-h1-min: 1.125rem ✔️,--fs-h1-min: 1.125 ❌(少单位)font-size: clamp(var(--fs-h1-min), var(--fs-h1-vw), var(--fs-h1-max)) ✔️font-size: clamp(1rem, calc(var(--fs-h1-vw) + 0.25rem), 2rem) ✔️(calc() 内变量必须自带单位)font-size: clamp(var(--fs-h1-min), 4vw, var(--fs-h1-max)) ❌(中间项没走变量,无法批量调控)开发时看着正常,上线后用户反馈“字太小”,往往卡在这些细节:iPhone 横屏时 vw 突然变大,导致 clamp() 冲到上限;部分安卓 WebView(如微信内嵌页)禁用 viewport 缩放,vw 计算失准;首次渲染时旧版 Samsung Internet 可能回退到最小值。
<meta name="viewport" content="width=device-width, initial-scale=1"> 是否存在且生效4vw——先测真实容器宽度,再反推合理系数font-size: 1.25rem; font-size: clamp(...);,让不支持 clamp() 的浏览器 fallback