Elem módosítása id alapján JavaScriptben
Tegyük fel, hogy a arr változóban
egy objektumtömb található:
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',
},
];
Tegyük fel, hogy meg szeretnénk változtatni egy elemet a tömbben. Tegyük fel, hogy az új adatok egy változóban tárolódnak, például így:
let data = {
id: 'IWSpfBPSV3SXgRF87uO74',
prop1: 'value21 !',
prop2: 'value22 !',
prop3: 'value23 !',
};
A megadott objektumban a id megegyezik
a tömb második elemének id értékével, míg a
tulajdonságok értékei eltérőek. Más szavakkal,
a data objektum id tulajdonságában azon
tömbelem id értéke található, amelyet
meg szeretnénk változtatni.
Végezzük el ezt a módosítást. Ehhez
egy ciklussal bejárjuk a tömb elemeit,
és ha a id megegyezik a keresett értékkel, akkor
lecseréljük az elemet, ha nem egyezik, akkor
változatlanul hagyjuk:
let res = arr.map(elem => {
if (elem.id === data.id) {
return data;
} else {
return elem;
}
});
A kód rövidíthető a ternális operátor használatával:
let res = arr.map(elem => elem.id === data.id ? data : elem);
Tegyük fel, hogy egy változóban egy tömbelem
id értéke tárolódik. Készítsen egy gombot, amelyre
kattintva a megfelelő tömbelem
módosul.