news 2026/4/16 19:04:37

Next.js路由段配置选项笔记

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Next.js路由段配置选项笔记

来是想发昨晚写好的 starblog 管理后台重构文章的

结果打开 blog 才发现忘记提交了😂

所以写一篇新的吧

正好最近正在大量使用 Next.js

我发现部署后的首次渲染很慢,才意识到「预热」这个问题

当然这是后话了

这个框架里有大量的官方约定

这些在官方文档里都有的,就是比较分散,本文主要是概括一下这些约定

Next.js框架更新得很快,不一样的地方以官方文档为主。

缓存和渲染相关#

// 控制页面重新验证的时间间隔(秒)

export const revalidate = 60; // 60秒后重新验证

export const revalidate = 0; // 禁用缓存

export const revalidate = false; // 永久缓存

// 控制页面的渲染模式

export const dynamic = 'auto'; // 默认,自动选择

export const dynamic = 'force-dynamic'; // 强制动态渲染

export const dynamic = 'force-static'; // 强制静态渲染

export const dynamic = 'error'; // 如果使用动态函数则报错

// 控制动态段的行为

export const dynamicParams = true; // 允许动态参数(默认)

export const dynamicParams = false; // 不允许动态参数

运行时配置#

// 指定运行时环境

export const runtime = 'nodejs'; // Node.js 运行时(默认)

export const runtime = 'edge'; // Edge 运行时

// 设置最大执行时间(秒)

export const maxDuration = 30; // 最多执行30秒

获取数据相关#

// 控制 fetch 请求的缓存行为

export const fetchCache = 'auto'; // 默认缓存行为

export const fetchCache = 'default-cache'; // 默认缓存

export const fetchCache = 'only-cache'; // 只使用缓存

export const fetchCache = 'force-cache'; // 强制缓存

export const fetchCache = 'default-no-store'; // 默认不缓存

export const fetchCache = 'only-no-store'; // 只允许不缓存

export const fetchCache = 'force-no-store'; // 强制不缓存

元数据和SEO#

元数据#

动态生成元数据

import type { Metadata } from 'next'

export async function generateMetadata({ params }: { params: { slug: string } }): Promise<Metadata> {

// 根据动态参数获取数据

const post = await getPost(params.slug)

return {

title: post.title,

description: post.description,

openGraph: {

title: post.title,

description: post.description,

images: [post.image],

},

}

}

定义静态元数据

// 静态元数据

export const metadata: Metadata = {

title: 'My Page',

description: 'This is my page description',

keywords: ['next.js', 'react', 'typescript'],

openGraph: {

title: 'My Page',

description: 'This is my page description',

},

}

使用场景#

静态 Metadata 适用于:

内容固定的页面(如关于我们、联系我们)

不需要根据路由参数变化的页面

简单的静态页面

动态 Metadata 适用于:

博客文章详情页(根据文章 slug 获取标题、描述)

产品详情页(根据产品 ID 获取信息)

用户个人资料页(根据用户 ID 获取信息)

任何需要根据路由参数或外部数据动态生成 metadata 的页面

静态参数#

// 生成静态参数(用于动态路由)

export async function generateStaticParams() {

return [

{ slug: 'post-1' },

{ slug: 'post-2' },

];

}

常用组合示例#

完全静态页面#

export const dynamic = 'force-static';

export const revalidate = false;

实时动态页面#

export const dynamic = 'force-dynamic';

export const revalidate = 0;

定时更新页面#

export const revalidate = 3600; // 每小时更新一次

Edge 运行时优化#

export const runtime = 'edge';

export const dynamic = 'force-dynamic';

API 路由配置#

// 在 API 路由中也可以使用

export const runtime = 'edge';

export const maxDuration = 10;

使用场景建议#

配置 适用场景

revalidate = 0 实时数据展示,如股票价格、聊天应用

revalidate = 60 定期更新的内容,如新闻、博客

dynamic = 'force-static' 完全静态的页面,如关于我们

dynamic = 'force-dynamic' 个性化内容,如用户仪表板

runtime = 'edge' 需要低延迟的全球分发

fetchCache = 'force-no-store' 敏感数据,不允许缓存

注意事项#

只能在页面或布局文件中使用 :这些配置只在 page.tsx 、 layout.tsx 或 route.ts 文件中有效

这些配置选项只能在 Server Component Pages、Layouts 或 Route Handlers 中使用

必须是具名导出 :必须使用 export const 语法

配置值必须是 静态可分析的 (例如 revalidate = 600 有效,但 revalidate = 60 * 10 无效)

类型安全 :TypeScript 会检查这些配置的类型

优先级 :子路由的配置会覆盖父路由的配置

这些配置选项让 Next.js 能够精确控制每个页面的渲染和缓存行为,是 App Router 架构的核心特性之一

官方文档#

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 7:43:38

手握方向盘急打方向时,你有没有想过轮胎和车身的相互作用到底藏着什么玄机?今天咱们用Matlab扒开车辆动力学的底裤,看看那个决定车辆会不会失控的神秘相平面

基于Matlab的车辆稳定性相平面图绘制程序 ①根据确定的简化魔术公式轮胎模型&#xff0c;建立车辆非线性二自由度运动微分方程&#xff0c;并进而对相平面图进行绘制。 ②包括横摆角速度与质心侧偏角的相平面&#xff0c;以及质心侧偏角速度与质心侧偏角的相平面。 附带说明文档…

作者头像 李华
网站建设 2026/4/17 12:25:16

三菱FX5U与3台三菱E700变频器通讯实战

三菱FX5U与3台三菱E700变频器通讯程序(SL5U-24) 通讯说明&#xff1a;用三菱FX5U的PLC实现与3台三菱E700变频器modbus通讯 器件&#xff1a;三菱FX5U PLC&#xff0c;3台三菱E700变频器&#xff0c;昆仑通态TPC7022NI触摸屏 功能&#xff1a;触摸屏上设置每台频率&#xff0c;监…

作者头像 李华
网站建设 2026/4/17 6:04:26

Profiling 专项

Profiling 工具 https://github.com/iovisor/bcc

作者头像 李华
网站建设 2026/4/17 7:43:36

如何完成一个方便简单的Arduino共阳极数码管实验(从0~9依次循环亮起)

文章目录 实验演示共阴极数码管和共阳极数码管的区别所需器材连接草图程序代码代码说明代码功能概述核心数据结构关键函数逻辑 小结 实验演示 共阴极数码管和共阳极数码管的区别 在开始实验之前&#xff0c;请让我简单解释一下共阴极数码管和共阳极数码管的区别&#xff0c;这…

作者头像 李华
网站建设 2026/4/17 8:53:55

Sniffnet容器化部署终极指南:3步搞定网络流量监控

还在为复杂的网络分析工具配置头疼吗&#xff1f;Sniffnet容器化部署让你在5分钟内拥有专业级网络流量分析能力&#xff01;告别环境依赖冲突&#xff0c;开启零基础网络分析新时代 &#x1f680; 【免费下载链接】sniffnet Sniffnet 是一个能让你轻松监测网络流量的应用。你可…

作者头像 李华
网站建设 2026/4/17 7:43:53

基于Python+Django的毕业设计选题系统(源码+lw+部署文档+讲解等)

课题介绍本课题聚焦高校毕业设计选题环节的管理痛点&#xff0c;设计实现一套基于 PythonDjango 框架的毕业设计选题系统。传统毕业设计选题多依赖线下提交、人工统计&#xff0c;易出现选题冲突、信息不对称、流程效率低等问题&#xff0c;难以适配高校规模化教学管理需求。系…

作者头像 李华