ErrorBoundary
Remix の ErrorBoundary
コンポーネントは、通常の React のエラー境界とほぼ同じように動作しますが、いくつかの追加機能があります。ルートコンポーネントでエラーが発生した場合、ErrorBoundary
はその代わりに、親ルート内にネストされてレンダリングされます。ErrorBoundary
コンポーネントは、ルートの loader
または action
関数でエラーが発生した場合にもレンダリングされるため、そのルートのすべてのエラーを 1 か所で処理できます。
最も一般的なユースケースは次のとおりです。
- 意図的に 4xx
Response
をスローしてエラー UI をトリガーする場合があります。- 不正なユーザー入力で 400 をスローする
- アクセスが許可されていない場合に 401 をスローする
- 要求されたデータが見つからない場合に 404 をスローする
- レンダリング中にランタイムエラーが発生した場合、React が意図せずに
Error
をスローする場合があります。
スローされたオブジェクトを取得するには、useRouteError
フックを使用できます。Response
がスローされると、state
/ statusText
/ data
フィールドを持つ ErrorResponse
インスタンスに自動的にアンラップされるため、コンポーネントで await response.json()
を使用する必要はありません。スローされた Response
をスローされた Error
と区別するには、isRouteErrorResponse
ユーティリティを使用できます。