最稳妥方式是在HTML的中用引入Google Fonts并添加display=swap参数,配合带系统后备字体的font-family兜底链,可有效缓解FOIT/FOUT问题。
直接在 里用 引入最稳妥,比 @import 更早触发字体下载,避免 FOIT(Flash of Invisible Text)或 FOUT(Flash of Unstyled Text)加重。
Inter 或 Roboto),点击右下角「+」添加到收藏,再点「Family Selected」获取嵌入代码 标签(含 display=swap 参数),粘贴到 HTML 的 中,例如:display=swap 是关键:它让浏览器先用系统后备字体渲染文字,等自定义字体加载完成再替换,用户体验更平滑别只写 font-family: 'Inter',必须带兜底链(fallback stack),否则字体加载失败或未命中时会退成无衬线默认字体,样式可能突变。
body { font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;}'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 策略阻止