Project Icon

fontaine

基于字体指标优化网页性能的自动化工具

fontaine 是一款基于字体指标自动生成本地字体后备方案的工具,能有效减少累积布局偏移(CLS)。该工具通过纯 CSS 实现,无运行时开销,自动生成字体指标和覆盖。fontaine 兼容 Vite、Next.js、Docusaurus 和 Gatsby 等多种框架,集成简便。

fontaine

npm 版本 npm 下载量 Github Actions Codecov

基于字体度量的自动字体回退

特性

  • 💪 通过使用精心设计的字体度量的本地字体回退来减少 CLS。
  • ✨ 自动生成字体度量和覆盖。
  • ⚡️ 纯 CSS,零运行时开销。

在演示项目中,启用/禁用 fontaine 可以在渲染 / 时产生以下差异,无需任何自定义:

之前之后
CLS0.240.054
性能92100

安装

使用 pnpm

pnpm add -D fontaine

或者,使用 npm

npm install -D fontaine

或者,使用 yarn

yarn add -D fontaine

使用方法

import { FontaineTransform } from 'fontaine'

// Astro 配置 - astro.config.mjs
import { defineConfig } from 'astro/config'

const options = {
  fallbacks: ['BlinkMacSystemFont', 'Segoe UI', 'Helvetica Neue', 'Arial', 'Noto Sans'],
  // 你可能需要将资源如 `/fonts/Roboto.woff2` 解析到特定目录
  resolvePath: id => `file:///path/to/public/dir${id}`,
  // overrideName: (originalName) => `${name} override`
  // sourcemap: false
  // skipFontFaceGeneration: (fallbackName) => fallbackName === 'Roboto override'
}

// Vite
export default {
  plugins: [FontaineTransform.vite(options)]
}

// Next.js
export default {
  webpack(config) {
    config.plugins = config.plugins || []
    config.plugins.push(FontaineTransform.webpack(options))
    return config
  },
}

// Docusaurus 插件 - 提供给 docusaurus.config.js 的 plugins 选项
// 注意:你可能需要使用 require 而不是 import 来引入 fontaine
const fontaine = require('fontaine')

function fontainePlugin(_context, _options) {
  return {
    name: 'fontaine-plugin',
    configureWebpack(_config, _isServer) {
      return {
        plugins: [
          fontaine.FontaineTransform.webpack(options),
        ],
      }
    },
  }
}

// Gatsby 配置 - gatsby-node.js
const { FontaineTransform } = require('fontaine')

exports.onCreateWebpackConfig = ({ stage, actions, getConfig }) => {
  const config = getConfig()
  config.plugins.push(FontaineTransform.webpack(options))
  actions.replaceWebpackConfig(config)
}

export default defineConfig({
  integrations: [],
  vite: {
    plugins: [
      FontaineTransform.vite({
        fallbacks: ['Arial'],
        resolvePath: id => new URL(`./public${id}`, import.meta.url), // id 是 CSS 中的字体 src 值
      }),
    ],
  },
})

注意 如果你使用 Nuxt,请查看 nuxt-font-metrics,它在底层使用了 fontaine

如果你的自定义字体是通过 CSS 变量机制使用的,你需要对 CSS 变量进行一些调整以帮助 fontaine。Docusaurus 就是一个例子,它使用 --ifm-font-family-base 变量来引用自定义字体。为了让 fontaine 能够将变量与字体关联起来,我们需要在该变量中添加 {字体名称} override 后缀。这看起来是什么样的?假设我们使用的自定义字体是 Poppins,它通过 --ifm-font-family-base 变量引用,我们需要进行以下调整:

:root {
  /* ... */
-  --ifm-font-family-base: 'Poppins';
+  --ifm-font-family-base: 'Poppins', 'Poppins override';

在幕后,fontaine 创建了一个 'Poppins override' @font-face 规则。通过手动将这个覆盖字体系列添加到我们的 CSS 变量中,我们使我们的网站使用 fontaine 生成的具有正确字体度量的回退 @font-face 规则。

工作原理

fontaine 将扫描你的 @font-face 规则并生成具有正确度量的回退规则。例如:

@font-face {
  font-family: 'Roboto';
  font-display: swap;
  src: url('/fonts/Roboto.woff2') format('woff2'), url('/fonts/Roboto.woff')
      format('woff');
  font-weight: 700;
}
/* 这个额外的 font-face 声明将被添加到你的 CSS 中。 */
@font-face {
  font-family: 'Roboto override';
  src: local('BlinkMacSystemFont'), local('Segoe UI'), local('Helvetica Neue'),
      local('Arial'), local('Noto Sans');
  ascent-override: 92.7734375%;
  descent-override: 24.4140625%;
  line-gap-override: 0%;
}

然后,每当你使用 font-family: 'Roboto' 时,fontaine 将在 font-family 中添加覆盖:

:root {
  font-family: 'Roboto';
  /* 这将变成 */
  font-family: 'Roboto', 'Roboto override';
}

💻 开发

  • 克隆此仓库
  • 使用 corepack enable 启用 Corepack(对于 Node.js < 16.10,使用 npm i -g corepack
  • 使用 pnpm install 安装依赖
  • 使用 pnpm dev 运行交互式测试;使用 pnpm demo:dev 启动使用源代码的 vite 服务器

致谢

如果没有以下支持,这个项目将不可能实现:

许可证

用❤️制作

根据 MIT 许可证 发布。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号