Zmena jednej vlastnosti podľa id v JavaScripte
Môže byť potrebné zmeniť nie celý objekt, ale konkrétnu vlastnosť. Pozrime sa, ako sa to robí.
Nech v premennej arr je
pole objektov:
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',
},
];
Nech v premenných sú uložené id elementu,
názov vlastnosti na zmenu a nová hodnota
vlastnosti:
let id = 'IWSpfBPSV3SXgRF87uO74';
let prop = 'prop1';
let value = '!!!';
Na vyriešenie úlohy je vhodné použiť destructuring a vypočítateľné názvy vlastností:
let res = arr.map(elem => {
if (elem.id === id) {
return {...elem, [prop]: value};
} else {
return elem;
}
});
Sú dané nasledujúce premenné:
let id = 'JAmjRlfQT8rLTm5tG2m1L';
let prop = 'prop2';
Vytvorte tlačidlo, po kliknutí na ktoré sa
zoberie element poľa so zadaným id,
v ňom sa zoberie vlastnosť so zadaným
názvom a na koniec hodnoty tejto vlastnosti
sa pridá znak '!'.
Nech sú dané dve premenné s názvami vlastností:
let id = 'JAmjRlfQT8rLTm5tG2m1L';
let prop1 = 'prop2';
let prop2 = 'prop3';
Upravte predchádzajúcu úlohu tak, aby sa po kliknutí zmeny vykonali naraz pre dve zadané vlastnosti.
Upravte uvedené riešenie z teórie
na kopírovanie objektu pomocou Object.assign.