Задать вопрос
@Mysianio
вайти в айти

Не обновляется компонент после props, почему?

Здравствуйте, есть код, который принимает некие товары в пропсе.
Когда нажимаешь на кнопку 'добавить товар' то он добавляет его в корзину в redux.
При добавлении все работает отлично, однако неполадка с удалением из корзины.
Удаленные элементы пропадут из интерфейса только тогда, когда будет добавлен новый товар

С самим редаксом все вроде бы хорошо, он удаляет и добавляет элементы правильно, возвращает не мутировавший, а новый объект:

return {...cartInfo};

Вот так создаются элементы корзины:
useEffect(()=>{
        setList(props.cart.map((item, index) =>{
            return <OpenCartElement info={item} />
        }))
        
    },[props])


В чем может быть проблема?
  • Вопрос задан
  • 198 просмотров
Подписаться 1 Средний Комментировать
Помогут разобраться в теме Все курсы
  • Нетология
    Frontend-разработка на React
    10 недель
    Далее
  • ProductStar
    Разработка на React
    6 недель
    Далее
  • Яндекс Практикум
    React-разработчик
    3 месяца
    Далее
Решения вопроса 1
@Mysianio Автор вопроса
вайти в айти
Спасибо всем, кто помогал, дело было в том, что в редьюсере, я просто мутировал старый массив, вместо того чтобы передавать новый
Как было:
cartInfo.goodInfo.splice(i, 1);
Как стало:
cartInfo.goodInfo.splice(i, 1);
cartInfo.goodInfo = [...cartInfo.goodInfo];
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
Robur
@Robur
Знаю больше чем это необходимо
Для начала проверьте срабатывает ли эффект при удалении.
Ответ написан
Ваш ответ на вопрос

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

Похожие вопросы
от 250 000 до 300 000 ₽
ITK academy Нижний Новгород
от 50 000 до 90 000 ₽
ITK academy Екатеринбург
от 50 000 до 90 000 ₽