--- id: react-error-boundary title: React Error Boundary 패턴 category: Coding status: draft source_trust_level: B verification_status: conceptual created_at: 2026-05-09 updated_at: 2026-05-09 tags: [react, error-handling, resilience, vibe-coding] tech_stack: { language: "TypeScript / React 18+", applicable_to: ["Web", "React Native"] } applied_in: [] aliases: [componentDidCatch, fallback UI, react-error-boundary] --- # React Error Boundary 패턴 > render / lifecycle / constructor 에서 throw 된 에러를 잡아 fallback UI 표시. **이벤트 핸들러 / async / setTimeout 에러는 안 잡음** — 그건 일반 try/catch. ## 📖 핵심 개념 - Class component 만 가능 (Hook 형태 없음). `react-error-boundary` 라이브러리 함수 컴포넌트 wrapper. - 경계마다 isolated fallback. 트리 일부만 죽고 나머지 살아남기. ## 💻 코드 패턴 ### react-error-boundary 라이브러리 ```tsx import { ErrorBoundary } from 'react-error-boundary'; function Fallback({ error, resetErrorBoundary }: any) { return

오류: {error.message}

; } sendToSentry(err, info)} onReset={() => resetCacheKeys()}> ``` ### Suspense + ErrorBoundary 조합 ```tsx }> ``` ## 🤔 의사결정 기준 | 영역 | Error Boundary | try/catch | |---|---|---| | 컴포넌트 render 중 throw | ✅ | — | | useEffect 안의 async 에러 | ❌ | ✅ | | 이벤트 핸들러 (onClick) | ❌ | ✅ | | Suspense fallback 안의 throw | ✅ | — | | Server-side rendering 에러 | 부분 (Next.js error.tsx) | — | | 전역 unhandled rejection | ❌ | window.onunhandledrejection | ## ❌ 안티패턴 - **앱 루트에 하나만**: 한 컴포넌트 사고 = 전체 화면 흰색. 화면 영역마다 boundary. - **fallback 에서 동일 에러 다시 throw**: 무한 루프. - **에러 silently 삼킴**: 로깅 / 모니터링 (Sentry/Datadog) 필수. - **이벤트 핸들러 에러를 boundary 가 잡을 거라 가정**: 안 잡힘. 핸들러는 try/catch. - **resetErrorBoundary 호출 시 같은 에러 재발생**: 원인을 안 고치면 다시 throw. cache key reset / state reset 필수. - **production 에서 error.message 그대로 노출**: 보안 위험. 일반 메시지 + 내부 로깅 분리. ## 🤖 LLM 활용 힌트 - "data fetching 자식 마다 ErrorBoundary + Suspense 페어" 패턴 강제. - onError 에서 Sentry 등 외부 서비스 보고 명시. ## 🔗 관련 문서 - [[React_Suspense_for_Data]] - [[Error_Handling_Result_vs_Throw]]