Տարրի փոփոխում id-ի միջոցով JavaScript-ում
Ենթադրենք arr փոփոխականում պարունակվում է
օբյեկտների զանգված․
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',
},
];
Ենթադրենք ուզում ենք փոխել զանգվածի որևէ տարր։ Ենթադրենք նոր տվյալները պահվում են մի փոփոխականում, օրինակ, այսպիսիները․
let data = {
id: 'IWSpfBPSV3SXgRF87uO74',
prop1: 'value21 !',
prop2: 'value22 !',
prop3: 'value23 !',
};
Նշված data օբյեկտում id-ն համընկնում է
զանգվածի երկրորդ տարրի id-ի հետ, իսկ հատկությունների
արժեքները՝ այլ են։ Այլ կերպ ասած՝
data-ում id հատկության մեջ պահվում է
զանգվածի այն տարրի id-ն, որը
մենք ուզում ենք փոխել։
Եկեք կատարենք այս փոփոխությունը։ Դրա համար
կփնտրենք զանգվածի տարրերը ցիկլով
և, եթե id-ն համընկնում է փնտրվողի հետ, կկատարենք
տարրի փոխարինում, իսկ եթե չի համընկնում, կթողնենք
տարրը անփոփոխ․
let res = arr.map(elem => {
if (elem.id === data.id) {
return data;
} else {
return elem;
}
});
Կարելի է կրճատել կոդը՝ օգտագործելով եռակի օպերատորը․
let res = arr.map(elem => elem.id === data.id ? data : elem);
Ենթադրենք մի փոփոխականում պահվում է զանգվածի
տարրի id-ն։ Ստեղծեք կոճակ, որի սեղմման
դեպքում կփոխվի զանգվածի համապատասխան
տարրը։