新闻中心

Next.js 13 App Directory 中的按需重新验证

2025-10-11
浏览次数:
返回列表

next.js 13 app directory 中的按需重新验证

本文旨在讲解如何在 Next.js 13 的 App Directory 中实现按需重新验证 (On-Demand Revalidation)。通过 revalidateTag 和 revalidatePath,开发者可以精确控制特定页面或数据标签的缓存失效,从而在数据更新时触发页面重建,避免了全局定时重新构建的低效性。

在 Next.js 13 的 App Directory 中,按需重新验证 (On-Demand Revalidation) 是一种强大的特性,它允许开发者在特定事件发生时,精确地使缓存失效并重新生成页面。这与传统的基于时间的重新验证 (Time-Based Revalidation) 形成对比,后者需要定期重新构建整个站点或特定页面,效率较低。按需重新验证则更加灵活和高效,特别适用于需要实时更新数据的场景,例如博客文章更新、用户资料修改等。

使用 revalidateTag 进行数据标签重新验证

revalidateTag 允许你基于特定的数据标签来使缓存失效。这意味着你可以为你的数据请求添加标签,然后在数据更新时,通过 revalidateTag 来触发所有使用该标签的页面的重新生成。

以下是一个示例,展示了如何使用 revalidateTag 来重新验证用户数据:

// app/page.js
export default async function Page() {
  const user = await fetch("/api/user", { next: { tags: ["user"] } })
    .then(res => res.json());

  return <div>我是 {user.name},我的页面真漂亮</div>;
}

在这个例子中,我们使用 fetch 函数获取用户数据,并使用 next: { tags: ["user"] } 为该请求添加了一个名为 "user" 的标签。这意味着 Next.js 会将这个请求的结果与 "user" 标签关联起来。

接下来,我们需要一个触发重新验证的函数。这通常会在数据更新时被调用,例如在用户资料更新后:

// app/form/page.js
import { revalidateTag } from 'next/cache';

export default async function FormPage() {
  const updateUser = async (formData) => {
    'use server';
    const name = formData.get('name');

    // 模拟更新用户数据的 API 调用
    await fetch("/api/user/update", {
      method: 'POST',
      body: JSON.stringify({ name }),
    });

    revalidateTag("user"); // 触发 "user" 标签的重新验证
  };

  return (
    <>
      <form action={updateUser}>
        <input type="text" name="name" />
        <button type="submit">更新用户名</button>
      </form>

      <div>{/* 最新的用户数据将在这里显示 */}</div>
    </>
  );
}

在这个例子中,我们创建了一个名为 updateUser 的 Server Action,它在表单提交时被调用。该函数首先模拟更新用户数据的 API 调用,然后调用 revalidateTag("user") 来触发 "user" 标签的重新验证。这将导致所有使用 "user" 标签的页面(例如上面的 /app/page.js)重新生成,从而显示最新的用户数据。

秀脸FacePlay 秀脸FacePlay

一款集成AI换脸、照片跳舞等多种AI特效玩法的App

秀脸FacePlay 124 查看详情 秀脸FacePlay

关键点:

  • revalidateTag 必须在 Server Actions 或 Route Handlers 中使用。
  • 确保你的数据请求使用了 tags 选项,以便 Next.js 可以正确地跟踪依赖关系。

使用 revalidatePath 进行路径重新验证

revalidatePath 允许你基于特定的路径来使缓存失效。这对于需要在特定页面更新时触发重新生成的场景非常有用。

// app/api/update-blog-post/route.js
import { revalidatePath } from 'next/cache';
import { NextResponse } from 'next/server';

export async function POST(request) {
  // ... 处理博客文章更新的逻辑

  revalidatePath('/blog/[slug]'); // 重新验证 `/blog/[slug]` 路径
  return NextResponse.json({ revalidated: true, now: Date.now() });
}

在这个例子中,我们创建了一个 API 路由 /api/update-blog-post,它处理博客文章的更新。在更新完成后,我们调用 revalidatePath('/blog/[slug]') 来触发 /blog/[slug] 路径的重新验证。这将导致所有匹配该路径的页面(例如 /blog/my-first-post)重新生成,从而显示最新的博客文章内容。

关键点:

  • revalidatePath 必须在 Server Actions 或 Route Handlers 中使用。
  • 你可以使用通配符 [slug] 来匹配动态路由。

注意事项和总结

  • 按需重新验证是 Next.js 13 App Directory 中一项强大的特性,它允许你精确控制缓存失效和页面重新生成。
  • revalidateTag 适用于基于数据标签的重新验证,而 revalidatePath 适用于基于路径的重新验证。
  • 确保在 Server Actions 或 Route Handlers 中使用 revalidateTag 和 revalidatePath。
  • 合理使用按需重新验证可以提高应用程序的性能和用户体验,避免不必要的重新构建。

通过合理利用 revalidateTag 和 revalidatePath,开发者可以构建出更加动态和响应式的 Next.js 应用程序,满足各种实时数据更新的需求。

以上就是Next.js 13 App Directory 中的按需重新验证的详细内容,更多请关注其它相关文章!


# 服务端  # 漯河网站建设优化  # 河源外贸网站推广方案  # 西宁店铺装修seo优化  # 外贸营销网站推广 开发  # 济宁seo优化seo排名关键词排名  # 澳门营销推广方法  # 滨州网站建设设计软件  # 网站怎么优化都选j火11星  # 供求信息网站推广营销  # 太谷线上seo优化  # 应用程序  # 如何实现  # js  # 这将  # 博客  # 如何使用  # 表单  # 适用于  # 在这个  # 按需  # 表单提交  # 路由  # ai  # app  # json 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 《北京人工智能产业白皮书(2025)》发布:全年核心产值预计突破 4500 亿元  Python多版本共存与虚拟环境管理深度指南  Win11如何使用Windows Sandbox Win11沙盒功能开启与使用教程【详解】  Python字典中优雅地迭代剩余元素的方法  如何在Python中使用Optional类型处理可变对象并避免Pylint警告  天眼查怎么看公司融资情况 天眼查企业融资历史查询步骤【攻略】  生成rdflib自定义SPARQL函数:参数匹配与实践指南  KFC套餐升级怎么获取优惠代码_KFC套餐升级活动与优惠代码获取方法  Win10如何清理注册表垃圾 Win10手动清理无效注册表【技巧】  css卡片内容溢出如何处理_使用overflow隐藏或scroll显示内容  QQ邮箱登录平台入口 QQ邮箱网页版邮箱官方入口  优化Log4j2控制台输出性能:解决异步日志瓶颈  Golang并发任务中错误如何聚合_Golang goroutine error收集方式  Yandex免登录官网入口_俄罗斯Yandex搜索引擎直达链接  wps文字怎么插入目录并自动更新_wps文字如何插入目录并自动更新方法  sublime怎么预览Markdown渲染效果_Markdown Preview插件 for sublime教程  win11 arm版怎么安装 M1/M2 Mac虚拟机安装ARM win11的方法  红果短剧网页版官网入口 官方最新网址发布  将HTML Canvas内容转换为可上传的图像文件(File对象)  优化Django表单:提交验证失败后保留用户输入  sublime如何优雅地处理行尾空格_sublime自动清理多余空白字符配置  邮编格式怎么匹配地址_根据邮编格式快速匹配详细地址的技巧  格力空气能E5故障代码是什么情况_格力空气能E5代码解析与应对措施  Lar*el如何正确地在控制器和模型之间分配逻辑_Lar*el代码职责分离与架构建议  随机参数递归函数的基准调用次数与时间复杂度探究  Eclipse怎么运行工程_Eclipse工程运行配置说明  React Router v6 教程:构建认证保护的私有路由与重定向策略  免费抖音短视频入口_抖音网页版短视频免费通道  痛风发作了怎么办? 快速止痛和后期饮食调理  谷歌浏览器一键优化方案_谷歌浏览器直达主页极速不卡版  QQ邮箱正确登录入口_QQ邮箱官方网站使用地址  J*aScript教程:根据元素文本内容动态设置背景色  深入理解J*a编译器的兼容性选项:从-source到--release  迅雷下载到U盘速度很慢怎么办_迅雷U盘下载慢优化方法  vivo浏览器怎么扫描二维码 vivo浏览器内置扫一扫功能使用方法  word邮件合并后日期格式不对怎么改_Word邮件合并日期格式修改方法  小红书商家版怎样在笔记嵌入商品卡路径_小红书商家版在笔记嵌入商品卡路径【挂载教程】  HTML空白字符处理机制:渲染、DOM与编码实践  深入理解J*a合成构造器:何时以及为何阻止其生成  Django表单提交验证失败后保持字段值不刷新  支付宝如何设置安全保护_支付宝安全设置的全面教程  邮政快递单号查询入口 邮政快递物流信息在线查询入口  解决Rails应用中内容错位与Turbo警告:meta标签误用导致富文本渲染异常  包子漫画官方网站阅读入口-包子漫画在线漫画官网直达链接  Composer如何解决json扩展缺失的错误  2026春节假期时间安排 2026春节假日查询  聚水潭ERP登录页面入口 聚水潭ERP官网登录界面  探索高级语言到C/C++的转译路径:以Go为例及内存管理策略  QQ邮箱官方网站登录入口_QQ邮箱网页版在线使用  Python实现多节点属性重叠度分析教程 

搜索