メインコンテンツまでスキップ

notFound

notFound 関数を使用すると、ルートセグメント内で not-found ファイル をレンダリングし、<meta name="robots" content="noindex" /> タグを挿入することができます。

notFound()

notFound() 関数を呼び出すと、NEXT_NOT_FOUND エラーがスローされ、それがスローされたルートセグメントのレンダリングが終了します。 not-found ファイル を指定することで、セグメント内に Not Found UI をレンダリングして、このようなエラーを優雅に処理することができます。

app/user/[id]/page.js
import { notFound } from 'next/navigation'

async function fetchUser(id) {
const res = await fetch('https://...')
if (!res.ok) return undefined
return res.json()
}

export default async function Profile({ params }) {
const user = await fetchUser((await params).id)

if (!user) {
notFound()
}

// ...
}

Good to know: notFound() は TypeScript の never 型を使用しているため、return notFound() を使用する必要はありません。

バージョン履歴

VersionChanges
v13.0.0notFound が導入されました