unstable_noStore
unstable_noStore 可用于声明式地退出静态渲染,表明特定组件不应被缓存。
import { unstable_noStore as noStore } from 'next/cache';
export default async function Component() {
  noStore();
  const result = await db.query(...);
  ...
}须知:
unstable_noStore等效于在fetch中使用cache: 'no-store'- 相比
export const dynamic = 'force-dynamic',更推荐使用unstable_noStore,因为它更细粒度且可以基于单个组件使用
- 在 unstable_cache中使用unstable_noStore不会退出静态生成,而是会遵从缓存配置来决定是否缓存结果。
用法
如果您不想向 fetch 传递额外选项(如 cache: 'no-store' 或 next: { revalidate: 0 }),可以用 noStore() 替代所有这些用例。
import { unstable_noStore as noStore } from 'next/cache';
export default async function Component() {
  noStore();
  const result = await db.query(...);
  ...
}版本历史
| 版本 | 变更描述 | 
|---|---|
| v14.0.0 | 引入 unstable_noStore功能 |