Spreminjanje ene lastnosti po id v JavaScript
Morda boste morali spremeniti ne celoten objekt, ampak določeno lastnost. Poglejmo, kako se to naredi.
Naj v spremenljivki arr leži
polje 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',
},
];
Naj v spremenljivkah hranijo id elementa,
ime lastnosti za spreminjanje in nova vrednost
lastnosti:
let id = 'IWSpfBPSV3SXgRF87uO74';
let prop = 'prop1';
let value = '!!!';
Za rešitev problema je priročno uporabiti destrukcijo in izračunana imena lastnosti:
let res = arr.map(elem => {
if (elem.id === id) {
return {...elem, [prop]: value};
} else {
return elem;
}
});
Dane so naslednje spremenljivke:
let id = 'JAmjRlfQT8rLTm5tG2m1L';
let prop = 'prop2';
Naredite gumb, ob kliku na katerega bo
vzet element polja z navedenim id,
v njem bo vzeta lastnost z navedenim
imenom in na konec vrednosti te lastnosti
bo dodan znak '!'.
Naj sta dani dve spremenljivki z imeni lastnosti:
let id = 'JAmjRlfQT8rLTm5tG2m1L';
let prop1 = 'prop2';
let prop2 = 'prop3';
Spremenite prejšnjo nalogo tako, da ob kliku se spremembe izvedejo takoj za dve navedeni lastnosti.
Predelajte navedeno rešitev v teoriji
s kopiranjem objekta s pomočjo Object.assign.