自定义 TTF 字体在 React 应用程序中加载缓慢

Custom TTF fonts loading slowly in React app

我正在尝试在我的 React 应用程序中包含自定义字体(使用 create-react-app 制作)。它似乎有点工作,但仅在加载页面后 2-3 秒后。在此之前,文本似乎使用浏览器的默认字体(如 Times New Roman),然后在几秒钟后切换为自定义字体。有人可以向我解释为什么会发生这种情况以及我需要做些什么来解决这个问题吗?

我正在将字体导入我的顶级 App.js 文件,如下所示:

import './fonts/tarrgetital.ttf';
import './App.scss';

并在我的 App.scss 文件中声明如下:

@font-face {
    font-family: 'tarrgetital';
    src: local('tarrgetital'), url(./fonts/tarrgetital.ttf) format('truetype');
}

h2 {
    font-family: tarrgetital;
}

加载网络字体的延迟是一个预期的行为问题,它的发生是因为浏览器在检测到 DOM 元素时加载字体,该元素具有与字体匹配的 CSS 选择器规则,当 HTML 文件和所有 CSS 文件都已下载到客户端时,就会发生这种情况。这是一种延迟加载机制。有一些解决方案可以改善此行为:

  • 使用优化的网络字体文件:

    为了获得更好的性能,您可以在 font-face 与 woffwoff2 文件格式。这些格式是 压缩在 gzip 中,从而减少文件大小和初始 客户端下载时间。如果这些格式不可用 您可以使用众多在线工具之一来转换字体文件 (google TTF to woff2).


一种替代方法是使用 webfontloader。它由 Google 和 Typekit 共同开发。

npm i webfontloader

在您的 App.js 文件中添加这个。注意:您仍然需要在 css 文件中维护字体声明。

import WebFont from 'webfontloader';

WebFont.load({
    custom: {
      families: ['tarrgetital'],
    },
  });

我也在 index.css 文件上使用字体

@font-face {
  font-family: "Avenir";
  src: local("Avenir"),
    url("assets/fonts/AvenirNextLTPro-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}
 <link rel="stylesheet" href="../src/index.css" />

然后我将 index.css 文件导入 index.html,这对我有用。