notFound
notFound
関数を使用すると、ルートセグメント内で not-found ファイル
をレンダリングし、さらに <meta name="robots" content="noindex" />
タグを注入できます。
notFound()
notFound()
関数を呼び出すと NEXT_NOT_FOUND
エラーがスローされ、スローされたルートセグメントのレンダリングが終了します。not-found ファイル を指定することで、セグメント内で Not Found UI をレンダリングして、このようなエラーを適切に処理できます。
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()
}
// ...
}
補足:
notFound()
は TypeScript のnever
型を使用しているため、return notFound()
を使用する必要はありません。
バージョン履歴
バージョン | 変更内容 |
---|---|
v13.0.0 | notFound が導入されました。 |