Ændring af element efter id i JavaScript
Lad variablen arr indeholde
et array af objekter:
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',
},
];
Lad os sige, at vi vil ændre et element i arrayet. Lad de nye data være gemt i en variabel, for eksempel sådan her:
let data = {
id: 'IWSpfBPSV3SXgRF87uO74',
prop1: 'value21 !',
prop2: 'value22 !',
prop3: 'value23 !',
};
I det viste objekt matcher id
id for det andet element i arrayet, mens værdierne
for egenskaberne er andre. Med andre ord,
i data gemmes i egenskaben id
id for det array-element, som
vi vil ændre.
Lad os udføre denne ændring. For at gøre dette
vil vi gennemgå elementerne i arrayet med en løkke
og, hvis id matcher den søgte, udfører vi
erstatning af elementet, og hvis det ikke matcher, lader vi
elementet være uændret:
let res = arr.map(elem => {
if (elem.id === data.id) {
return data;
} else {
return elem;
}
});
Koden kan forkortes ved at bruge den ternære operator:
let res = arr.map(elem => elem.id === data.id ? data : elem);
Lad en variabel indeholde id for et element
i arrayet. Lav en knap, der ved klik
ændrer det tilsvarende
element i arrayet.