Use .push para atualizar o componente [duplicado]
Nov 21 2020
Não é possível atualizar o dom após usar o objeto .push array ser atualizado
const [people, setPeople] = React.useState(data);
const addItem = () => {
const itemName = document.querySelector('.input').value;
const i = people.length + 1;
people.push({
id: i,
name: itemName
});
setPeople(people);
console.log(people);
}
Respostas
ThalesKenne Nov 21 2020 at 00:01
Isso ocorre porque o push altera o estado original e você não deve alterar o estado manualmente em react.
Em vez disso, crie uma cópia superficial de seu estado, empurre e redefina o estado com a matriz alterada.
const [people, setPeople] = React.useState(data);
const addItem = () => {
const itemName = document.querySelector('.input').value;
const i = people.length + 1;
const newPeople = [...people]; // Create a copy
newPeople.push({
id: i,
name: itemName
});
setPeople(newPeople);
console.log(newPeople);
}
RajithaUdayanga Nov 21 2020 at 00:04
const addItem = () => {
const itemName = document.querySelector('.input').value;
const i = people.length + 1;
// crate new people
const newPeople = {
id: i,
name: itemName
};
// concat to existing peoples and set to state
setPeople(prevState => prevState.concat(newPeople));
console.log(people);
}
O que significa um erro “Não é possível encontrar o símbolo” ou “Não é possível resolver o símbolo”?