Skip to content

connection

Source URL: https://nextjs.org/docs/app/api-reference/functions/connection

The connection() function allows you to indicate rendering should wait for an incoming user request before continuing.

It’s useful when a component doesn’t use Dynamic APIs, but you want it to be dynamically rendered at runtime and not statically rendered at build time. This usually occurs when you access external information that you intentionally want to change the result of a render, such as Math.random() or new Date().

import { connection } from 'next/server'
export default async function Page() {
await connection()
// Everything below will be excluded from prerendering
const rand = Math.random()
return <span>{rand}</span>
}
import { connection } from 'next/server'
export default async function Page() {
await connection()
// Everything below will be excluded from prerendering
const rand = Math.random()
return <span>{rand}</span>
}
function connection(): Promise<void>
  • The function does not accept any parameters.
  • The function returns a void Promise. It is not meant to be consumed.
  • connection replaces unstable_noStore to better align with the future of Next.js.
  • The function is only necessary when dynamic rendering is required and common Dynamic APIs are not used.
VersionChanges
v15.0.0connection stabilized.
v15.0.0-RCconnection introduced.