Next.js13集成GoogleFonts新教程
还在为 Next.js 13+ 项目中集成 Google Fonts 而烦恼吗?本文为你带来最新的解决方案!告别传统的 `` 标签和 `@import` 方式,利用 Next.js 内置的 `next/font/google` 模块,轻松实现 Google Fonts 的集成和优化。本文将详细介绍如何在 Next.js 13+ 项目中使用 `next/font/google` 模块,配置字体、全局应用,并在 CSS 中使用自定义字体变量,实现零布局偏移和高性能加载。掌握 Next.js 13+ 字体管理的新范式,让你的网站拥有更快的加载速度和更出色的用户体验!

Next.js 13+ 字体管理的新范式
在 Next.js 13 及更高版本中,随着 App Router 的引入,管理外部字体(尤其是 Google Fonts)的方式发生了显著变化。过去常用的在 _document.js 或 _app.js 中添加 标签,或者在全局 CSS 文件中使用 @import 规则的方法,可能不再适用或不再是最佳实践。Next.js 官方推荐使用内置的 next/font 模块来处理字体,它提供了自动字体优化、零布局偏移(CLS)以及更好的性能体验。
next/font 模块会自动下载 Google Fonts 并在构建时进行自托管,从而避免了浏览器对外部资源的额外请求,并消除了布局偏移。它还支持定义 CSS 变量,使得在应用程序的任何地方使用字体变得非常方便。
使用 next/font/google 集成 Google Fonts
以下是在 Next.js 13+ 项目中集成 Google Fonts 的详细步骤。我们将以 Poppins 字体为例。
步骤一:在 app/layout.js 中配置字体
在 Next.js 13 的 App Router 架构中,app/layout.js 文件是应用程序的根布局。我们将在该文件中导入并配置 Google Fonts。
首先,从 next/font/google 导入你需要的字体。例如,要导入 Poppins 字体,你可以这样做:
import { Poppins } from 'next/font/google';
// 配置 Poppins 字体
const poppins = Poppins({
subsets: ['latin'], // 指定字体子集,减少文件大小
display: 'swap', // 控制字体加载行为,'swap' 表示使用系统字体直到自定义字体加载完成
variable: '--font-poppins', // 定义一个 CSS 变量名,方便在 CSS 中引用
weight: ['100', '200', '300', '400', '500', '600', '700', '800', '900'] // 指定需要加载的字重
});
export const metadata = {
title: '您的页面标题',
description: '您的页面描述',
}
export default function RootLayout({ children }) {
return (
// 将字体变量应用到 元素
{children}
)
}配置选项说明:
- subsets: 数组类型,指定需要加载的字符子集。这有助于减小字体文件大小,提高加载速度。例如 ['latin']。
- display: 字符串类型,控制字体加载时的显示行为。
- swap: 字体加载期间使用系统字体,加载完成后替换为自定义字体(推荐,可避免文本不可见,但可能出现布局偏移)。
- optional: 浏览器决定是否使用自定义字体。
- block: 字体加载期间显示空白。
- fallback: 类似于 swap,但有更短的阻塞期。
- variable: 字符串类型,定义一个 CSS 变量名。Next.js 会生成一个包含字体族名称的 CSS 变量,例如 --font-poppins,你可以在 CSS 中使用 var(--font-poppins) 来引用该字体。
- weight: 数组或字符串类型,指定需要加载的字重。例如 ['400', '700'] 或 '400'。如果需要所有字重,可以列出所有。
- style: 数组或字符串类型,指定需要加载的字体样式(如 ['normal', 'italic'])。
步骤二:在 CSS 中使用自定义字体
一旦在 app/layout.js 中配置并应用了字体变量,你就可以在项目中的任何 CSS/SCSS/Tailwind CSS 文件中使用这个 CSS 变量了。
例如,在你的全局 CSS 文件(如 app/globals.css)或任何组件的 CSS 模块中:
/* app/globals.css 或其他 CSS 文件 */
body {
/* 使用定义的 CSS 变量来应用 Poppins 字体 */
font-family: var(--font-poppins), sans-serif;
}
.custom-text {
font-family: var(--font-poppins), serif;
font-weight: 500; /* 可以结合字重使用 */
}这样,body 或 .custom-text 元素将应用 Poppins 字体。
注意事项与最佳实践
性能优势: next/font 模块通过自动自托管和减少网络请求,显著提高了字体加载性能。它还通过内联 CSS 和 font-display: optional 或 swap 来最小化布局偏移。
子集选择: 务必根据你的项目需求选择合适的 subsets。加载不必要的字符子集会增加字体文件大小,影响加载速度。
字重和样式: 只加载你实际需要的字重和样式。加载过多的字重也会增加字体文件大小。
display 属性: display: 'swap' 是一个很好的默认选择,因为它允许文本在字体加载时立即显示(使用系统字体),避免了“不可见文本闪烁”(FOIT)。
多个字体: 如果你需要使用多个 Google Fonts,可以重复上述步骤,为每个字体定义一个不同的 CSS 变量,并在 元素上拼接多个变量。例如:
import { Inter, Poppins } from 'next/font/google'; const inter = Inter({ subsets: ['latin'], variable: '--font-inter' }); const poppins = Poppins({ subsets: ['latin'], variable: '--font-poppins', weight: ['400', '700'] }); export default function RootLayout({ children }) { return ( {children} ) }然后在 CSS 中分别使用 var(--font-inter) 和 var(--font-poppins)。
本地字体: next/font 也支持本地字体。对于本地字体,你需要使用 next/font/local 模块。
总结
Next.js 13+ 引入的 next/font 模块是管理 Google Fonts 的现代化、高性能解决方案。它简化了字体集成过程,并通过自动化优化确保了出色的用户体验。通过遵循本文提供的步骤,你可以轻松地在 Next.js 项目中引入并应用自定义 Google Fonts,同时享受到框架带来的性能优势。告别传统方法,拥抱 next/font,让你的应用程序拥有更快的加载速度和更平滑的视觉呈现。
本篇关于《Next.js13集成GoogleFonts新教程》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!
Golangstrings.Builder用法与实例详解
- 上一篇
- Golangstrings.Builder用法与实例详解
- 下一篇
- 淘宝双十一降价提醒怎么设置
-
- 文章 · 前端 | 1星期前 | 定时器 · 前端 · 性能排查 · 接口请求 · 轮询 · setInterval · setInterval 页面可见性 clearInterval 前端轮询 请求堆积 定时器清理
- 前端轮询接口越打越多怎么办:从重复定时器到清理机制一步步排查
- 490浏览 收藏
-
- 文章 · 前端 | 1星期前 | 前端 · 搜索框 · AbortController · 接口请求 · 状态管理 · Fetch AbortController 前端搜索 请求乱序 旧响应覆盖
- 前端搜索结果倒退怎么办:AbortController 取消旧请求和序号兜底
- 295浏览 收藏
-
- 文章 · 前端 | 1星期前 | 前端 · 性能优化 · cls · 懒加载 · Core Web Vitals · 前端 图片懒加载 IntersectionObserver CLS 布局稳定
- 前端图片懒加载布局抖动治理完整流程:占位比例、按需加载和 CLS 复查
- 128浏览 收藏
-
- 文章 · 前端 | 1星期前 | 工程化 · 前端 · javascript · css · 弹窗 · 前端 z-index 遮罩层 stacking context Portal 弹窗层级
- 前端弹窗层级治理工作流:从 z-index 混乱到 Portal 容器规范
- 350浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ljg-skills
- ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
- 2109次使用
-
- MELO音乐
- MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
- 1956次使用
-
- UniScribe
- UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
- 1896次使用
-
- 剧云
- 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
- 2100次使用
-
- 万象有声
- 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
- 2089次使用
-
- JavaScript函数定义及示例详解
- 2025-05-11 502浏览
-
- CSS变量简化按钮悬停效果技巧
- 2026-05-31 501浏览
-
- JavaScript符号类型详解与应用
- 2026-05-31 501浏览
-
- HTML剪贴板复制粘贴怎么用
- 2026-05-26 501浏览
-
- data-*属性详解:HTML数据存储与DOM操作技巧
- 2026-05-25 501浏览

