Son el mecanismo principal para el manejo de errores en aplicaciones React.
Puntos de control
¿Por qué necesitamos Error Boundaries?
¿Qué pueden y qué no pueden capturar?
Implementación de un Error Boundary
Uso práctico de Error Boundaries
CONCEPTO CLAVE: Los Error Boundaries son componentes React especiales que capturan errores de JavaScript en cualquier parte de su árbol de componentes, los registran y muestran una UI alternativa en lugar de bloquear toda la aplicación. Son el mecanismo principal para el manejo de errores en aplicaciones React.
¿Por qué necesitamos Error Boundaries?
En las aplicaciones React modernas, los errores en un componente pueden propagarse y destruir toda la interfaz de usuario. Imagina que un pequeño componente de botón falla: sin Error Boundaries, toda tu aplicación se volvería inoperable. Los Error Boundaries actúan como "contenedores de seguridad" que aíslan los errores y mantienen funcionando el resto de la aplicación.
📌 Los Error Boundaries fueron introducidos en React 16 como parte del concepto de "Error Boundaries" o "límites de error". Son fundamentales para crear aplicaciones React robustas y profesionales.
¿Qué pueden y qué no pueden capturar?
Es crucial entender las limitaciones de los Error Boundaries:
Pueden capturar
No pueden capturar
Errores en renderización
Eventos (onClick, onChange, etc.)
Métodos del ciclo de vida
Código asíncrono (setTimeout, Promises)
Constructores de componentes
Errores fuera del árbol de componentes
Errores en hooks personalizados
El propio Error Boundary
Implementación de un Error Boundary
Para crear un Error Boundary, necesitas una clase de componente React que implemente uno o ambos de estos métodos estáticos:
class ErrorBoundary extends React.Component {
constructor(props) {
super(props);
this.state = { hasError: false, error: null, errorInfo: null };
}
static getDerivedStateFromError(error) {
// Actualiza el estado para mostrar la UI de respaldo
return { hasError: true };
}
componentDidCatch(error, errorInfo) {
// Puedes registrar el error en un servicio externo
console.error('Error capturado:', error, errorInfo);
logErrorToMyService(error, errorInfo);
}
render() {
if (this.state.hasError) {
return (
<div className="error-fallback">
<h2>Algo salió mal</h2>
<details>
<summary>Ver detalles del error</summary>
<p>{this.state.error && this.state.error.toString()}</p>
</details>
</div>
);
}
return this.props.children;
}
}
💡 Tip: getDerivedStateFromError() se usa para renderizar la UI alternativa, mientras que componentDidCatch() es ideal para logging y reporting de errores a servicios externos como Sentry, Bugsnag o tu propio backend.
Uso práctico de Error Boundaries
Ahora veamos cómo aplicar el Error Boundary en tu aplicación:
import React from 'react';
import ErrorBoundary from './ErrorBoundary';
import Header from './Header';
import Content from './Content';
import Sidebar from './Sidebar';
function App() {
return (
<div className="app">
<Header />
<ErrorBoundary>
<Sidebar />
</ErrorBoundary>
<ErrorBoundary>
<Content />
</ErrorBoundary>
);
}
// También puedes crear múltiples Error Boundaries específicos
function Dashboard() {
return (
<ErrorBoundary fallback={
⚠️ Advertencia: No envuelvas toda tu aplicación en un solo Error Boundary. Esto haría que al fallar cualquier componente, toda la aplicación muestre la misma interfaz de error. Usa múltiples Error Boundaries para aislar componentes específicos y mantener funcionando el resto.
Manejo de errores en código asíncrono
Los Error Boundaries NO capturan errores en manejadores de eventos, callbacks asíncronos o Promises. Para estos casos, necesitas usar try-catch tradicional:
function UserProfile({ userId }) {
const [user, setUser] = React.useState(null);
const [error, setError] = React.useState(null);
React.useEffect(() => {
async function fetchUser() {
try {
const response = await fetch(`/api/users/${userId}`);
if (!response.ok) throw new Error('Usuario no encontrado');
const data = await response.json();
setUser(data);
} catch (err) {
setError(err.message);
}
}
fetchUser();
}, [userId]);
if (error) return <ErrorMessage message={error} />;
if (!user) return <LoadingSpinner />;
return <Profile user={user} />;
}
📌 Este patrón es útil cuando necesitas pasar callbacks adicionales al fallback, como una función para reintentar la operación o resetear el estado del componente.
💡 Tip profesional: Implementa niveles de recuperación progresiva. Si un componente falla, intenta recuperación automática. Si falla repetidamente, muestra opciones más drásticas como recargar la sección o la página completa.
Estrategias de monitoreo y logging
Para aplicaciones en producción, es esencial registrar los errores capturados:
⚠️ Importante: Nunca expongas información sensible del error en la UI de producción. Los stack traces detallados deben enviarse solo a tus servicios de logging, nunca al usuario final.
Integración con React Router
Un patrón común es combinar Error Boundaries con React Router para manejar errores de navegación:
Aísla los errores: Coloca Error Boundaries en niveles estratégicos de tu aplicación, no envolver todo.
Proporciona contexto: Muestra mensajes útiles al usuario sin exponer detalles técnicos sensibles.
Implementa logging: Envía los errores a un servicio de monitoreo para poder depurarlos.
Ofrece recuperación: Incluye opciones para reintentar o navegar a un estado seguro.
Prueba tus Error Boundaries: Simula errores intencionalmente para verificar que funcionan correctamente.
Los Error Boundaries son como los airbags de tu aplicación: esperas no necesitarlos, pero cuando ocurre un error, son la diferencia entre una recuperación suave y un fracaso total.
📌 Recuerda: los Error Boundaries no pueden manejar todos los tipos de errores. Para eventos, Promises y código asíncrono, siempre usa try-catch tradicional junto con el manejo de estado de React.
Ejercicio práctico
Implementa un Error Boundary que:
Muestre un mensaje amigable cuando un componente falla
Tenga un botón "Reintentar" que recupere el componente
Registre los errores en la consola
Limit los reintentos a 3 intentos antes de mostrar un mensaje de "contactar soporte"
🧠 Quiz: Error Boundaries
¿Cuál de los siguientes errores SÍ puede capturar un Error Boundary?
A) Errores en manejadores onClick
B) Errores en Promises con await
C) Errores durante el renderizado de un componente
D) Errores en setTimeout
✅ Respuesta correcta: C) Errores durante el renderizado. Los Error Boundaries capturan errores en el render, métodos del ciclo de vida y constructores. NO capturan errores en manejadores de eventos, código asíncrono (setTimeout, Promises) ni fuera del árbol de componentes.
Conclusión
Los Error Boundaries son una herramienta esencial para crear aplicaciones React robustas y profesionales. Combinados con manejo de errores tradicional en código asíncrono y sistemas de logging externos, te permiten crear experiencias de usuario resilientes donde incluso cuando algo falla, la aplicación puede recuperarse elegantemente. Practica implementando Error Boundaries en diferentes niveles de tu aplicación y siempre prueba sus comportamientos bajo condiciones de error.
Laboratorio de práctica
Antes de marcar esta lección como completa, escribí una evidencia breve para React Intermedio: Dominando Componentes y Patrones Avanzados: un ejemplo, una decisión, una captura, una mini demo o una nota que puedas reutilizar en portfolio.
Reflexión rápida
¿Qué cambiarías en tu forma de trabajar después de aplicar error boundaries y manejo de errores en react?
De lección a portfolio
Convertí esta lección en una prueba técnica visible.
Una app pequeña publicada, con README y decisiones explicadas, funciona mejor que una lista de tecnologías sueltas.
Paso 1
Creá una demo mínima que use el concepto de la lección.
Paso 2
Escribí un README corto con objetivo, stack, decisión técnica y mejora futura.
Paso 3
Publicá la demo y enlazala desde tu perfil profesional.