Zmiana elementu po id w JavaScript
Niech w zmiennej arr znajduje się
tablica obiektów:
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',
},
];
Załóżmy, że chcemy zmienić jakiś element tablicy. Niech nowe dane są przechowywane w zmiennej, na przykład takie:
let data = {
id: 'IWSpfBPSV3SXgRF87uO74',
prop1: 'value21 !',
prop2: 'value22 !',
prop3: 'value23 !',
};
W podanym obiekcie id pasuje
do id drugiego elementu tablicy, a wartości
właściwości są inne. Innymi słowy,
w data we właściwości id przechowujemy
id tego elementu tablicy, który
chcemy zmienić.
Wykonajmy tę zmianę. W tym celu
będziemy iterować elementy tablicy pętlą
i, jeśli id pasuje do szukanego, wykonamy
zamianę elementu, a jeśli nie pasuje, pozostawimy
element bez zmian:
let res = arr.map(elem => {
if (elem.id === data.id) {
return data;
} else {
return elem;
}
});
Można skrócić kod, korzystając z operatora trójargumentowego:
let res = arr.map(elem => elem.id === data.id ? data : elem);
Załóżmy, że w zmiennej jest przechowywany id elementu
tablicy. Stwórz przycisk, po naciśnięciu
którego zostanie zmieniony odpowiedni
element tablicy.