カスタムエラー
404 ページ
404 ページは非常に頻繁にアクセスされる可能性があります。アクセスごとにエラーページをサーバーレンダリングすると、Next.jsサーバーの負荷が増加します。これにより、コストの増加とエクスペリエンスの低下につながる可能性があります。
上記の落とし穴を回避するために、Next.js は追加のファイルを追加しなくても、デフォルトで静的な 404 ページを提供します。
404 ページをカスタマイズする
カスタムの 404 ページを作成するには、pages/404.js
ファイルを作成します。このファイルはビルド時に静的に生成されます。
export default function Custom404() {
return <h1>404 - Page Not Found</h1>
}
知っておくと良いこと: ビルド時にデータをフェッチする必要がある場合は、このページ内で
getStaticProps
を使用できます。
500 ページ
アクセスごとにエラーページをサーバーレンダリングすると、エラーへの対応が複雑になります。エラーへの応答をできるだけ早くユーザーに届けるために、Next.js は追加のファイルを追加しなくても、デフォルトで静的な 500 ページを提供します。
500 ページをカスタマイズする
500 ページをカスタマイズするには、pages/500.js
ファイルを作成します。このファイルはビルド時に静的に生成されます。
export default function Custom500() {
return <h1>500 - Server-side error occurred</h1>
}
知っておくと良いこと: ビルド時にデータをフェッチする必要がある場合は、このページ内で
getStaticProps
を使用できます。
さらに高度なエラーページのカスタマイズ
500 エラーは、クライアント側とサーバー側の両方で Error
コンポーネントによって処理されます。これをオーバーライドしたい場合は、ファイル pages/_error.js
を定義し、次のコードを追加します
function Error({ statusCode }) {
return (
<p>
{statusCode
? `An error ${statusCode} occurred on server`
: 'An error occurred on client'}
</p>
)
}
Error.getInitialProps = ({ res, err }) => {
const statusCode = res ? res.statusCode : err ? err.statusCode : 404
return { statusCode }
}
export default Error
pages/_error.js
は本番環境でのみ使用されます。開発環境では、エラーが発生した場所を知るためのコールスタック付きのエラーが表示されます。
組み込みのエラーページの再利用
組み込みのエラーページをレンダリングしたい場合は、Error
コンポーネントをインポートすることで可能です。
import Error from 'next/error'
export async function getServerSideProps() {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const errorCode = res.ok ? false : res.status
const json = await res.json()
return {
props: { errorCode, stars: json.stargazers_count },
}
}
export default function Page({ errorCode, stars }) {
if (errorCode) {
return <Error statusCode={errorCode} />
}
return <div>Next stars: {stars}</div>
}
Error
コンポーネントは、statusCode
とともにテキストメッセージを渡したい場合に、title
をプロパティとして受け取ります。
カスタムのError
コンポーネントがある場合は、代わりにそちらをインポートしてください。next/error
は、Next.jsで使用されるデフォルトのコンポーネントをエクスポートします。
注意点
Error
は現在、データフェッチングメソッドであるgetStaticProps
やgetServerSideProps
などのNext.jsの機能には対応していません。_error
は、_app
と同様に予約済みのパス名です。_error
は、エラーページのカスタマイズされたレイアウトと動作を定義するために使用されます。/_error
は、ルーティングを介して直接アクセスした場合や、カスタムサーバーでレンダリングした場合に404をレンダリングします。
お役に立ちましたか?