Spreminjanje elementa po id v JavaScript
Naj bo v spremenljivki arr shranjeno
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',
},
];
Recimo, da želimo spremeniti kakšen element polja. Naj bodo novi podatki shranjeni v spremenljivki, na primer takšni:
let data = {
id: 'IWSpfBPSV3SXgRF87uO74',
prop1: 'value21 !',
prop2: 'value22 !',
prop3: 'value23 !',
};
V navedenem objektu id ustreza
id drugega elementa polja, vrednosti
lastnosti pa so drugačne. Z drugimi besedami,
v data je v lastnosti id shranjen
id tistega elementa polja, ki ga
želimo spremeniti.
Izvedimo to spremembo. Za to bomo
prebirali elemente polja s ciklusom
in, če id ustreza iskanemu, izvedli
zamenjavo elementa, če pa ne ustreza, pustili
element nespremenjen:
let res = arr.map(elem => {
if (elem.id === data.id) {
return data;
} else {
return elem;
}
});
Kodo lahko skrajšamo z uporabo ternarnega operatorja:
let res = arr.map(elem => elem.id === data.id ? data : elem);
Naj bo v spremenljivki shranjen id elementa
polja. Naredite gumb, ob kliku na
katerega bo spremenjen ustrezen
element polja.