HTML中使用CSS的font-weight属性可以控制文字的粗细程度。该属性接受多种值,包括关键字和数值,用于定义字体的粗细。1. 关键字值normal:默认值,表示正常粗细。bold:加粗。bolder:比父元素更粗。lighter:比父元素更细。示例:p { font-weight: bold; /* 文字加粗 */ }2. 数值值100 到 900 之间的整数,表示不同的粗细级别。数值
时间:2026-05-13 15:51:35 303浏览 收藏
HTML中CSS的font-weight属性看似简单,实则暗藏诸多实践陷阱:关键字如bold虽易用却受限于字体固有字重(常仅支持400/700),而数值写法(100–900)才能精准表达粗细意图、支持平滑升级(如800/900),前提是字体文件必须真实包含对应字重,否则浏览器会静默降级;更需警惕引号误写、非整百数无效、bolder不可控、a标签被默认样式覆盖,以及Windows下因缺失字重触发“fake bold”导致文字发虚等典型问题——真正可靠的加粗,始于对字体加载、元数据匹配与运行时验证的全程掌控。

font-weight 数值写法比 bold 更可靠
直接写 font-weight: bold 看似简单,但实际效果受限于字体本身是否提供真正的 bold 字重。很多系统字体(如 Windows 的微软雅黑、macOS 的 -apple-system)只内置 400 和 700 两级,bold 就是 700,再没更粗的选项。而用数值能明确表达意图,也方便后续扩展——比如想比 bold 还粗一点,font-weight: 800 或 900 就是唯一出路。
常见误区:
font-weight: "bold"加了引号 → 语法错误,浏览器忽略该声明font-weight: bolder嵌套多层后不可控 → 它不固定,依赖父元素当前值,父是 400 时它变 700,父是 700 时它可能卡在 700 不动(因字体无 800)font-weight: 650→ 非整百数,所有浏览器都当无效值处理,静默 fallback 到 600 或 700
字体支持决定 font-weight 实际效果
font-weight: 900 写得再对,如果当前字体文件没打包 900 字重,浏览器就自动降级到最近可用值(比如 700),且不报错、不提示。你在 DevTools 的 Computed 面板里看到的解析值才是真实生效的字重。
验证和应对方式:
- 用 Google Fonts 时,必须显式加载对应字重链接,例如
https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700;900,漏掉900就用不上 - 自定义字体用
@font-face时,font-weight声明必须与实际 .woff2 文件的元数据一致,否则浏览器无法匹配 - 可调用
document.fonts.check('900 Roboto')在运行时判断是否加载成功(注意:需等字体加载完成后再查)
font-weight 在 a 标签或内联元素上容易失效
超链接 默认没有加粗,但设了 font-weight: 700 却没反应?大概率是被用户代理样式或更高优先级规则覆盖了。Chrome/Firefox 对 的默认 font-weight 是 400,但某些 UI 框架(如 Bootstrap)会全局重置为 normal,导致你的声明被压制。
排查要点:
- 打开 DevTools → Elements → 右侧 Styles 面板,看
font-weight是否被划掉(strikethrough),被划掉说明有更高优先级规则在起作用 - 检查是否用了
!important—— 它能强制生效,但掩盖了真正的问题来源 - 确认选择器权重足够:比如
a.bold-link比a更高,.nav a又比单独a高
Windows 下 font-weight 渲染发虚的根本原因
文字加粗后边缘模糊、有毛边,尤其在 Chrome + Windows 组合下高频出现。这不是 CSS 写错了,而是浏览器在找不到对应字重时,用算法“fake bold”强行加粗:横向拉伸笔画,破坏字体 hinting 信息,导致抗锯齿失真。
真正有效的解法只有两个:
- 确保字体文件包含你要的字重(如 Roboto 900、Inter 800),并用
@font-face或 Google Fonts 正确加载 - 启用可变字体(variable fonts):用
font-weight: 100 900范围声明,配合支持的字体(如font-family: 'Inter', sans-serif),就能平滑调节,避免 fake bold
别用 text-shadow 或 -webkit-font-smoothing 补救——前者加重模糊,后者影响整块文本清晰度,治标不治本。
终于介绍完啦!小伙伴们,这篇关于《HTML中使用CSS的font-weight属性可以控制文字的粗细程度。该属性接受多种值,包括关键字和数值,用于定义字体的粗细。1. 关键字值normal:默认值,表示正常粗细。bold:加粗。bolder:比父元素更粗。lighter:比父元素更细。示例:p { font-weight: bold; /* 文字加粗 */ }2. 数值值100 到 900 之间的整数,表示不同的粗细级别。数值越大,字体越粗。常见的数值有:400(等同于 normal)、700(等同于 bold)。示例:h1 { font-weight: 700; /* 等同于加粗 */ }3. 注意事项并非所有字体都支持所有的 font-weight 值,某些字体可能只提供 normal 和 bold。使用数值时需确保字体支持对应的粗细级别。4. 实际应用
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
243 收藏
-
463 收藏
-
132 收藏
-
292 收藏
-
309 收藏
-
254 收藏
-
267 收藏
-
391 收藏
-
308 收藏
-
256 收藏
-
191 收藏
-
303 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习