5-1-COMPONENTE
Diferentes Formas de Crear Componentes en React
En React, existen varias formas de definir componentes. Las más comunes son usando funciones normales y funciones flecha (arrow functions). Aquí te explico cada una:
1. Función Normal (Function Declaration)
function MiComponente(props) {
// Lógica JavaScript aquí
const mensaje = "Hola desde función normal";
// El return devuelve JSX (HTML-like)
return (
<div>
<h1>{mensaje}</h1>
<p>{props.mensajeProp}</p>
</div>
);
}2. Función Flecha (Arrow Function)
const MiComponenteFlecha = (props) => {
// Lógica JavaScript aquí
const mensaje = "Hola desde función flecha";
// Return implícito (sin llaves) para componentes simples
// O explícito (con llaves) para componentes más complejos
return (
<div>
<h2>{mensaje}</h2>
<p>{props.mensajeProp}</p>
</div>
);
}💡 Explicación Clave:
Parte JavaScript: Antes del
returnpuedes escribir cualquier lógica JavaScript normal (variables, condicionales, loops, etc.)JSX: Lo que devuelve el
returnes JSX (JavaScript XML), una sintaxis que parece HTML pero:Usa
classNameen lugar declassLas expresiones JS van entre
{}Es transformado a JavaScript puro por Babel
🚀 Ejemplo de uso:
function App() {
return (
<div>
<MiComponente mensajeProp="Soy una prop"/>
<MiComponenteFlecha mensajeProp="Soy otra prop"/>
</div>
);
}🔍 ¿Cuál usar?
Funciones normales: Más tradicional, mejor para componentes complejos
Funciones flecha: Más concisas, ideales para componentes simples
Ambas son válidas y funcionan igual en React moderno (con Hooks). ¡Elige la que prefieras!
Guía Esencial de Componentes en React
Los componentes son bloques independientes y reutilizables que devuelven elementos HTML. Funcionan como funciones de JavaScript, pero están optimizados para construir interfaces.
🔷 Tipos de Componentes
1. Componentes de Función (Recomendados)
function Car() {
return <h2>¡Soy un Coche!</h2>;
}2. Componentes de Clase (Legacy)
class Car extends React.Component {
render() {
return <h2>¡Soy un Coche!</h2>;
}
}💡 Nota: Hoy se prefieren los componentes de función + Hooks (desde React 16.8).
🎯 Regla Clave
Nombres en mayúscula:
Car, nocar.
🔄 Cómo Usar un Componente
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<Car />); // Renderiza: <h2>¡Soy un Coche!</h2>🎁 Props: Personaliza tus Componentes
Las props son como argumentos que pasas a un componente:
function Car(props) {
return <h2>¡Soy un {props.color}!</h2>;
}
// Uso:
<Car color="rojo" /> // Renderiza: ¡Soy un rojo!🧩 Anidar Componentes
Puedes combinar componentes dentro de otros:
function Garage() {
return (
<>
<h1>¿Quién está en mi garaje?</h1>
<Car /> // Renderiza el componente Car
</>
);
}📂 Organización en Archivos
Mejor práctica: Guardar cada componente en un archivo separado (Car.js):
// Car.js
function Car() {
return <h2>¡Soy un Coche!</h2>;
}
export default Car;
// App.js
import Car from './Car.js';
root.render(<Car />);🚀 Conclusión
Componentes = Bloques reutilizables que generan HTML.
Props = Personalización (como atributos HTML).
Organiza en archivos para mantener el código limpio.
Comentarios
Publicar un comentario