Dux-Courses Evaluaciones
DOCUMENTATIONCOURSESROADMAPRANKINGBLOGPLAYGROUND
LoginSign Up
Aurum-Courses

Aurum Courses is an advanced learning and evaluation platform designed to accelerate your tech career. We provide an immersive environment filled with challenges, technical documentation, and verifyable certificates for frontend, backend, and fullstack technologies.

Platform Links

  • Interactive Courses
  • Technical Documentation
  • Tech Blog & Articles
  • Mi Perfil y Progreso

About the Project

  • About the Project
  • Contact & Support

Legal & Compliance

  • Privacy Policy
  • Terms of Service
  • Cookies Management
© 2026 Aurum-Courses. All rights reserved. Made with passion for the developer ecosystem.

Desarrollado por Aurumdux

Docs/React/useState: Estado Local
Principiantereact

useState: Estado Local

El hook useState permite gestionar estado reactivo dentro de componentes funcionales.

Que es el estado

El estado es informacion que un componente mantiene y que puede cambiar con el tiempo. Cuando el estado cambia, React re-renderiza el componente automaticamente para reflejar los nuevos datos en la interfaz.

Uso basico de useState

useState retorna un array con dos elementos: el valor actual del estado y una funcion para actualizarlo.
jsx
1import { useState } from "react";
2
3function Contador() {
4  const [count, setCount] = useState(0);
5
6  return (
7    <div>
8      <p>Contador: {count}</p>
9      <button onClick={() => setCount(count + 1)}>+1</button>
10      <button onClick={() => setCount(0)}>Reset</button>
11    </div>
12  );
13}

Estado con objetos

Al actualizar objetos en el estado, debes crear una nueva referencia (spread operator). React compara por referencia, no por valor profundo.
jsx
1function FormularioContacto() {
2  const [form, setForm] = useState({
3    nombre: "",
4    email: "",
5    mensaje: ""
6  });
7
8  const handleChange = (e) => {
9    const { name, value } = e.target;
10    setForm(prev => ({ ...prev, [name]: value }));
11  };
12
13  return (
14    <form>
15      <input name="nombre" value={form.nombre} onChange={handleChange} />
16      <input name="email" value={form.email} onChange={handleChange} />
17      <textarea name="mensaje" value={form.mensaje} onChange={handleChange} />
18    </form>
19  );
20}
← AnteriorComponentes FuncionalesSiguiente →useEffect: Efectos Secundarios