Modificando um elemento por id em JavaScript
Suponha que a variável arr contenha
um array de objetos:
let arr = [
{
id: 'GYi9GauC4gBF1e2SixDvu',
prop1: 'value11',
prop2: 'value12',
prop3: 'value13',
},
{
id: 'IWSpfBPSV3SXgRF87uO74',
prop1: 'value21',
prop2: 'value22',
prop3: 'value23',
},
{
id: 'JAmjRlfQT8rLTm5tG2m1L',
prop1: 'value31',
prop2: 'value32',
prop3: 'value33',
},
];
Suponha que queremos modificar algum elemento do array. Suponha que os novos dados estejam armazenados em uma variável, por exemplo, assim:
let data = {
id: 'IWSpfBPSV3SXgRF87uO74',
prop1: 'value21 !',
prop2: 'value22 !',
prop3: 'value23 !',
};
No objeto fornecido, o id coincide
com o id do segundo elemento do array, mas os valores
das propriedades são diferentes. Em outras palavras,
em data, na propriedade id, armazenamos
o id do elemento do array que
desejamos modificar.
Vamos realizar essa modificação. Para isso,
percorreremos os elementos do array com um loop
e, se o id coincidir com o que procuramos, realizaremos
a substituição do elemento; se não coincidir, deixaremos
o elemento inalterado:
let res = arr.map(elem => {
if (elem.id === data.id) {
return data;
} else {
return elem;
}
});
Podemos encurtar o código usando o operador ternário:
let res = arr.map(elem => elem.id === data.id ? data : elem);
Suponha que uma variável armazene o id de um elemento
do array. Crie um botão que, ao ser clicado,
modificará o elemento correspondente
do array.