Změna prvku podle id v JavaScriptu
Nechť v proměnné arr je
pole objektů:
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',
},
];
Předpokládejme, že chceme změnit nějaký prvek pole. Nechť nová data jsou uložena v proměnné, například takto:
let data = {
id: 'IWSpfBPSV3SXgRF87uO74',
prop1: 'value21 !',
prop2: 'value22 !',
prop3: 'value23 !',
};
V uvedeném objektu id se shoduje
s id druhého prvku pole, ale hodnoty
vlastností jsou jiné. Jinými slovy,
v data je ve vlastnosti id uloženo
id toho prvku pole, který
chceme změnit.
Proveďme tuto změnu. K tomu
budeme prvky pole procházet cyklem
a pokud se id shoduje s hledaným, provedeme
výměnu prvku, a pokud se neshoduje, ponecháme
prvek beze změny:
let res = arr.map(elem => {
if (elem.id === data.id) {
return data;
} else {
return elem;
}
});
Kód lze zkrátit pomocí ternárního operátoru:
let res = arr.map(elem => elem.id === data.id ? data : elem);
Nechť v proměnné je uloženo id prvku
pole. Vytvořte tlačítko, po jehož stisknutí
se změní odpovídající
prvek pole.