169 похожих чатов

Подскажите, пожалуйста: если использовать redux и хуки, как можно получить

ответ из экшена?
В случае с классовым компонентом можно сделать const res = await this.props.someAction()
А с хуками через dispatch как можно получить результат?

13 ответов

16 просмотров

Что мешает так же в пропсах получать экшены?

А зачем вам это надо?

Anatoly-Berbeka Автор вопроса
Gert
Что мешает так же в пропсах получать экшены?

Не совсем понял. Так у меня экшен импортируется, с этим проблем нет. Просто через dispatch(someAction()) я же не могу получить результат из экшена

Anatoly Berbeka
Не совсем понял. Так у меня экшен импортируется, с...

А ты проверь. Если не путаю, dispatch возвращает результат вызова экшена.

Anatoly-Berbeka Автор вопроса
Volodymyr Klimov
А зачем вам это надо?

Замороченная авторизация, поэтому все запросы через экшены, а мне надо получить url от сервера в данном случае. Можно, конечно, всё в redux совать, но я наоборот сейчас хочу максимально разгрузить redux

Anatoly-Berbeka Автор вопроса
Anatoly-Berbeka Автор вопроса
Volodymyr Klimov
можете Но я считаю, это не нужно

Приложение на RN. Токен имеет короткий срок жизни, плюс его постоянно обновлять надо, и постоянно проверять ответ сервера на валидность токена (типа чтоб исключить параллельные сессии). Поэтому у меня отдельный экшен есть, для проверки токена и обновления, если нужно. Удобнее всю эту логику в экшенах держать, чем везде гонять

Anatoly-Berbeka Автор вопроса
Anatoly-Berbeka Автор вопроса
Volodymyr Klimov
Но это не особо "redux-way"

Да я считаю что это абсолютно уродский костыль. Но я не нашёл более красивого решения. Если кто-то может подсказать или показать, как такое правильно обрабатывать - буду премного благодарен. Помимо прочего мне приходится в экшенах дёргать localStorage, чтоб достать токен и рефреш. Мне это тоже не нравится, но везде прокидывать токен тоже как-то не очень удобно

Anatoly Berbeka
Да я считаю что это абсолютно уродский костыль. Но...

правильней будет получать данные не просто в экшене, а подготовить отдельный модуль HTTP, в котором будум методы createRequest, checkAuth, validationRequest. Если возвращается 401 (unauthorized), повторно обращаться за акцес-токеном, имея на руках рефреш-токен. данные с бека не тупо кидать в стор, а маппить через DTO

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

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта