Задать вопрос
newdecline
@newdecline
Front-end-developer

Почему это работает?

Есть метод класса, он меняет состояние important.

onToggleImportant = (id) => {
        this.setState(({todoData}) => {
            return {
                todoData: this.toggleProperty(todoData, id, 'important')
            };
        });
    };


А есть метод который обрабатывает аргументы и возвращает массив

toggleProperty(arr, id, propName) {
        const index = arr.findIndex((el) => el.id === id);
        const oldItem = arr[index];
        const newItem = {...oldItem, [propName]: !oldItem[propName]};
        return [
            ...arr.slice(0, index),
            newItem,
            ...arr.slice(index + 1),
        ];
    }


Я вот не пойму почему работает деструктурирование для массива в
const newItem = {...oldItem, [propName]: !oldItem[propName]};
  • Вопрос задан
  • 211 просмотров
Подписаться 1 Простой 2 комментария
Решения вопроса 1
tsepen
@tsepen
Frontend developer
Это свойство объекта. в JS можно обратиться к свойству либо через точку либо через квадратные скобки. В квадратных скобках используют вычисляемое значение, например если заранее неизвестно к какому свойству будем обращаться - как в вашем случае

Например
const obj = {
value: 1
}

obj.value = 2

obj['value'] = 3


Вот варианты как обратиться и изменить значение
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы