одной функции, но при этом его значение не подхватывается другой, и там остаётся старое?
а нужно?
нужно подписаться на эту переменную через`useCallback`, тогда будет ловить
Мне особо не приходилось с usecallback работать, что в него надо обернуть?
не, я глянул на код выше, там проблема в другом. надо бы переписать, избавившись от forEach
А если мне надо пробегаться по массиву в поисках совпадения инпута с одним из значений массива, а потом то же самое со вторым инпутом сделать, и когда они оба совпадут, выполнить код?
отфильтруй что нужно, и в конце измени состояние один раз. реакту полегче будет )
так я и его и так один раз же изменяю
да эт понятно. вижу, что хочешь один раз вызвать, но у тебя цикл в цикле. алгоритмически не выгодно.
ну тут соглы, но проблема со стейтом разве в этом?
обращайся к event.target.value, а не к firstTextFieldValue - может поможет?
да-да, это у меня так и было, я для наглядности вернул обратно, потому что у меня в этом же коде есть ситуация, где я не могу по event.target.value смотреть в другой функции, там нужно именно по состоянию поля
я думаю, проблема в том, что у тебя firstTextFieldHandler не является чистой функцией. либо ее обернуть в useCallback(() => {}, [...deps]), указав массив переменных от которых она зависит, либо раскидать код по эффектам (для влияния на другие поля)
Обсуждают сегодня