Изменение элемента по 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 !',
};
В приведенном объекте 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
элемента
массива. Сделайте кнопку, по нажатию на
которую будет изменен соответствующий
элемент массива.