最稳妥方式是在HTML的中用引入Google Fonts并添加display=swap参数,配合带系统后备字体的font-family兜底链,可有效缓解FOIT/FOUT问题。

怎么在 CSS 中正确引入 Google Fonts 字体
直接在 里用 引入最稳妥,比 @import 更早触发字体下载,避免 FOIT(Flash of Invisible Text)或 FOUT(Flash of Unstyled Text)加重。
- 访问 Google Fonts,选中需要的字体(比如
Inter或Roboto),点击右下角「+」添加到收藏,再点「Family Selected」获取嵌入代码 - 复制生成的
标签(含display=swap参数),粘贴到 HTML 的中,例如: -
display=swap是关键:它让浏览器先用系统后备字体渲染文字,等自定义字体加载完成再替换,用户体验更平滑
如何在 CSS 中统一设置全局字体族
别只写 font-family: 'Inter',必须带兜底链(fallback stack),否则字体加载失败或未命中时会退成无衬线默认字体,样式可能突变。
- 推荐写法:
body { font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;} - 注意引号:Google Fonts 中带空格的字体名(如
'Open Sans')必须加单引号;系统字体名不带空格可不加(但加了也无害) - 不要把所有字体都堆进
body—— 如果项目里有代码块、表格、按钮等需差异化排版的元素,后续用更具体的 selector 覆盖即可
为什么字体没生效?常见排查点
不是链接没加,就是 CSS 优先级或字体名拼写出了问题。
- 检查浏览器开发者工具的
Network面板:确认fonts.googleapis.com请求返回 200,且响应内容是 CSS 规则(含@font-face声明) - 检查
Computed面板里的font-family值,看最终解析出的字体名是否和@font-face中的font-family完全一致(大小写、空格、引号都要对) - 避免在多个地方重复声明
@font-face或覆盖font-family,尤其当使用了 CSS-in-JS 或组件库时,容易被更高优先级规则压掉 - 国内访问
fonts.googleapis.com可能慢或不稳定,可考虑用国内镜像(如https://fonts.loli.net),但要注意镜像是否同步最新版本,且部分字体可能缺子集
要不要预加载关键字体?
对首屏核心文本(比如标题、正文)用的字体,值得加 ,但仅限 WOFF2 格式且只预载最关键的 1–2 个字重。
立即学习“前端免费学习笔记(深入)”;
- 示例(放在
中,位置在引入之后): - 注意必须加
crossorigin属性,否则字体加载会被 CORS 策略阻止 - URL 不能手写,要从 Google Fonts 返回的 CSS 中提取真实的 WOFF2 地址(查看网络请求的响应头或源码),不同字重 URL 不同
- 预加载不是万能的:如果字体文件大、CDN 延迟高,反而可能抢占其他关键资源带宽










