Modificarea unei proprietăți după id în JavaScript
S-ar putea să fie nevoie să modificați nu întregul obiect, ci o anumită proprietate. Să vedem cum se face acest lucru.
Să presupunem că variabila arr conține
un tablou de obiecte:
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',
},
];
Să presupunem că variabilele conțin id-ul elementului,
numele proprietății de modificat și noua valoare
a proprietății:
let id = 'IWSpfBPSV3SXgRF87uO74';
let prop = 'prop1';
let value = '!!!';
Pentru rezolvarea problemei este convenabil să folosiți destructurarea și numele de proprietăți calculate:
let res = arr.map(elem => {
if (elem.id === id) {
return {...elem, [prop]: value};
} else {
return elem;
}
});
Sunt date următoarele variabile:
let id = 'JAmjRlfQT8rLTm5tG2m1L';
let prop = 'prop2';
Creați un buton, la click pe care se va
lua elementul din tablou cu id-ul indicat,
în el se va lua proprietatea cu numele indicat
și la sfârșitul valorii acestei proprietăți
va fi adăugat semnul '!'.
Să presupunem că sunt date două variabile cu nume de proprietăți:
let id = 'JAmjRlfQT8rLTm5tG2m1L';
let prop1 = 'prop2';
let prop2 = 'prop3';
Modificați problema anterioară astfel încât la click modificările să se execute imediat pentru cele două proprietăți indicate.
Refaceți soluția dată în teorie
prin copierea obiectului cu Object.assign.