Next.js 提供了多种服务器端数据获取的方法,包括 getStaticProps 和 getServerSideProps。但是,这些方法主要适用于页面文件夹中的页面组件。在 Next.js 13 中,出现了一个称为服务器组件的新概念,允许直接在组件主体内获取数据。
服务器组件提供了更灵活的方法数据获取,使开发人员能够:
要使用服务器组件,请将您的组件定义为默认组件导出应用程序目录中的文件。可以使用以下方法在组件体内执行数据获取:
import { headers, cookies } from "next/headers"; export default async function Component({ params, searchParams }) { // Cached until manually invalidated const staticData = await fetch(`https://...`, { cache: "force-cache" }); // Refetched on every request const dynamicData = await fetch(`https://...`, { cache: "no-store" }); // Revalidated with a 10-second lifetime const revalidatedData = await fetch(`https://...`, { next: { revalidate: 10 } }); }
除了服务器组件之外,您还可以使用库或直接与数据库交互来获取数据使用 ORM。在这种情况下,你可以利用路由段配置:
// layout.js OR page.js OR route.js import prisma from "./lib/prisma"; // Caching options export const revalidate = 10; // Revalidate every 10s // OR export const dynamic = "force-dynamic"; // No caching async function getPosts() { const posts = await prisma.post.findMany(); return posts; } export default async function Page() { const posts = await getPosts(); }
通过使用服务器组件或替代方法,你可以在 Next.js 中高效地获取服务器上的数据,解决依赖时遇到的未定义数据的问题仅在 getStaticProps 上。
以上是如何在 Next.js 13 中高效地获取数据以避免未定义的数据?的详细内容。更多信息请关注PHP中文网其他相关文章!