state компонента, чтобы мутировать их в рамках компонента и гарантированно не было мутаций в контексте/редаксе?
Всегда просто присваивал типа stateObj: contextObj, а щас словил баг что первое обновление stateObj мутирует и contextObj. Причем мутация только в случае Set — когда меняю Set внутри stateObj.
А если присвоение stateObj делать раздельно по свойствам и свойство с Set как копию этого свойства у contextObj , то мутаций в контексте не будет:
1- получу мутацию contextObj.items при обновлении state
setStateObj: ({..., items: contextObj.items })
2- мутаций не будет
setStateObj: ({...,
items: new Set(contextObj.items)
})
Правильно всегда делать новую копию всего объекта contextObj при его присвоении statу или проблема только с Setами?
Если ты не будешь мутировать, проблемы не будет
ну я хочу обновлять state, не обновляя контекст, а первое обновление state мутирует и этот объект в контексте. Так же не должно быть? Обновляю state так, добавил new Setы специально но это не помогает: if (!stateObj.items) { setStateObj({ ..., items: new Set([item]) }); else { let items = new Set(stateObj.items.add(item)); setStateObj((prev) => ({ ...prev, items }));
Обмажутся своими мутациями а потом реакт чат мучают
Все прям как в Ведьмаке😂
Обсуждают сегодня