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

notFound

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

notFound()

notFound() 関数を呼び出すと、NEXT_NOT_FOUNDエラーがスローされ、スローされたルート Segment のレンダリングが終了します。not-found ファイルを指定して、Segment 内で 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(params.id)

if (!user) {
notFound()
}

// ...
}

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

Version 履歴

VersionChanges
v13.0.0notFound 導入