Změna jedné vlastnosti podle id v JavaScriptu
Může být potřeba změnit ne celý objekt, ale konkrétní vlastnost. Podívejme se, jak se to dělá.
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',
},
];
Nechť v proměnných jsou uloženy id prvku,
název vlastnosti pro změnu a nová hodnota
vlastnosti:
let id = 'IWSpfBPSV3SXgRF87uO74';
let prop = 'prop1';
let value = '!!!';
Pro řešení úlohy je vhodné použít destrukturalizaci a vypočítané názvy vlastností:
let res = arr.map(elem => {
if (elem.id === id) {
return {...elem, [prop]: value};
} else {
return elem;
}
});
Jsou dány následující proměnné:
let id = 'JAmjRlfQT8rLTm5tG2m1L';
let prop = 'prop2';
Vytvořte tlačítko, po jehož stisknutí se
vezme prvek pole se zadaným id,
v něm se vezme vlastnost se zadaným
názvem a na konec hodnoty této vlastnosti
se připíše znak '!'.
Nechť jsou dány dvě proměnné s názvy vlastností:
let id = 'JAmjRlfQT8rLTm5tG2m1L';
let prop1 = 'prop2';
let prop2 = 'prop3';
Upravte předchozí úlohu tak, aby po kliknutí byly změny provedeny najednou pro dvě zadané vlastnosti.
Předělejte uvedené řešení v teorii
pomocí kopírování objektu s použitím Object.assign.