• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

145
Vistas
El estado no está actualizado en las funciones de la matriz de componentes Reaccionar
import React, { useState } from "react"; const Person = ({ id, name, age, deleteThisPerson }) => { return ( <div className="person"> <p>{name}</p> <p>{age}</p> <button onClick={() => deleteThisPerson(id)}>Delete This Person</button> </div> ); }; const ArrayOfComponents = () => { const deleteThisPersonHandler = (id) => { console.log("[ArrayOfComponents] id : ", id); console.log("[ArrayOfComponents] personArrOfComp : ", personArrOfComp); }; const [personArrOfComp, setPersonArrOfComp] = useState([ <Person id="pc1" key="pc1" name="pc1" age={12} deleteThisPerson={deleteThisPersonHandler} />, ]); const addNewPersonHandler = () => { let r = new Date().getTime(); setPersonArrOfComp((prevState) => { return prevState.concat( <Person id={r} key={r} name={"PCC" + r} age={Math.floor(Math.random() * 100)} deleteThisPerson={deleteThisPersonHandler} /> ); }); }; return ( <div> <button onClick={addNewPersonHandler}>Add New Person</button> {personArrOfComp} </div> ); }; export default ArrayOfComponents;

Agregue algunas personas haciendo clic en el botón Agregar nueva persona . Después de eso, al hacer clic en el botón Eliminar esta persona , la función deleteThisPersonHandler muestra el estado anterior, no el estado más actual.

¿Alguien puede explicar este comportamiento de ReactJs? Por qué el estado no se actualiza en la función deleteThisPersonHandler después de agregar una nueva persona.

almost 3 years ago · Juan Pablo Isaza
3 Respuestas
Responde la pregunta

0

Es porque está poniendo componentes en estado que hacen referencia a una lambda que se cierra sobre una versión anterior de deleteThisPersonHandler .

Los componentes no son valores de estado de reacción apropiados. El estado debe ser la información más simple posible que su componente necesita almacenar para poder representar la interfaz de usuario. En este caso, probablemente sea una lista de identificaciones.

 const [persons, setPersons] = useState(["pc1"]); const addPerson = setPersons([...persons, Date.now()]); return {persons.map(p => <Person id={p} key={p} name={p} age={12} deleteThisPerson={deleteThisPersonHandler} />};

¡Allí, no hay componentes en el estado! Puede intercambiar las persons escalares con cualquier tipo de objeto complejo que necesite.

almost 3 years ago · Juan Pablo Isaza Denunciar

0

Es debido a deleteThisPersonHandler que está pasando como accesorio. En setPersonArrOfComp está configurando un nuevo estado, pero aún no se ha actualizado. Su función deleteThisPersonHandler que está pasando hace referencia al estado actual de personArrOfComp , y no al estado al que está intentando actualizar actualmente. Siempre será el estado anterior.

 setPersonArrOfComp((prevState) => { return prevState.concat( <Person id={r} key={r} name={"PCC" + r} age={Math.floor(Math.random() * 100)} deleteThisPerson={deleteThisPersonHandler} /> ); });
almost 3 years ago · Juan Pablo Isaza Denunciar

0

eso se debe a que usó un console.log() que muestra el estado anterior, no el estado actual, su trabajo ya está hecho pero es la naturaleza de console.log(). para que pueda mostrar su resultado como:

 const deleteThisPersonHandler = (id) => { alert("[ArrayOfComponents] id : "+ id); alert("[ArrayOfComponents] personArrOfComp : "+ personArrOfComp);

};

almost 3 years ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda