Redux-Thunk
3 minuty czytania
Redux-Thunk to biblioteka, która pozwala na wykonywanie operacji asynchronicznych w aplikacji opartej na Redux. Jest to jedno z najpopularniejszych rozszerzeń Redux, które pozwala na proste i czytelne zarządzanie stanem aplikacji.
Redux-Thunk jest dodatkiem do biblioteki Redux. Hostowany jako oddzielna paczka w NPM, jest możliwy do pobrania i ustawienia jako middleware przy inicjalizacji Redux bez skomplikowanej konfiguracji. Pozwala uzyskać asynchroniczność zapytań. Middleware'y w redux pozwalają przechwycić zapytanie i zamiast wykonać pojedynczą zmianę na storze może wykonać serię zapytań, w międzyczasie mogą odpytać API po zewnętrzne dane. Całość jest możliwa, do uzyskania bez Redux-Thunk, ale ten znacznie to ułatwia.
Przykładowe zapytanie w Redux-Thunk
Najprostszym przykładem wykorzystania Redux-Thunk będzie zapytanie do API w celu zalogowania użytkownika. Aby zapytanie przebiegło poprawnie musi wydarzyć się parę rzeczy.
1. Ustawienie stanu aplikacji, że logowanie się rozpoczęło.
2. Wysłanie zapytania do API
3. Ustawienie danych użytkownika w store
4. Ewentualne zwrócenie błędu
export const authLogin = (email, password) => {
return dispatch => {
dispatch(authStart());
axios
.post(`${API_URL}/auth/api/v1/login/`, {
email: email,
password: password
})
.then(res => {
const token = res.data.token;
const user = res.data.user;
dispatch(authSuccess(token, user));
})
.catch(err => {
dispatch(authFail(err));
});
};
};
Dzięki takiemu podejściu możemy wyizolować część logiki naszej aplikacji do pojedynczej funkcji. Możemy wykorzystać mockowanie danych z API i w pełni przetestować działanie takiego Thunka.
Obsługa błędów w Redux-Thunk
W każdej aplikacji korzystającej z asynchronicznych zapytań do API istotne jest odpowiednie zarządzanie błędami, aby zapewnić użytkownikowi jak najlepsze doświadczenie. Redux-Thunk pozwala na obsługę błędów w sposób elastyczny, umożliwiając zarówno reakcję na błędy w samych akcjach, jak i ich propagowanie do komponentów.
Jednym z kluczowych podejść jest przechwytywanie błędów bezpośrednio w funkcji thunk i aktualizowanie stanu aplikacji tak, aby można było np. wyświetlić komunikat o błędzie. Można również wykorzystać różne poziomy obsługi błędów – od prostych komunikatów po zaawansowane mechanizmy ponawiania zapytań (retry) czy globalne zarządzanie błędami.
Ważne jest także rozróżnianie typów błędów – niektóre mogą wynikać z problemów po stronie serwera (np. błędy HTTP 500), inne z braku połączenia internetowego, a jeszcze inne mogą być spowodowane niepoprawnymi danymi wejściowymi. Dzięki Redux-Thunk możliwe jest dostosowanie logiki obsługi błędów do konkretnych przypadków i odpowiednie reagowanie, np. poprzez automatyczne przekierowanie użytkownika, wyświetlenie powiadomienia lub zapisanie błędu w logach.
Dobrą praktyką jest także przechowywanie informacji o statusie zapytania w stanie Redux – dzięki temu aplikacja może dynamicznie reagować, np. poprzez wyświetlanie wskaźnika ładowania podczas przetwarzania zapytania i ukrywanie go w przypadku sukcesu lub błędu. Odpowiednia obsługa błędów w Redux-Thunk poprawia nie tylko stabilność aplikacji, ale także jej użyteczność i doświadczenie użytkownika.
Dlaczego warto używać Redux-Thunk?
Redux-Thunk to jedno z najpopularniejszych middleware do obsługi operacji asynchronicznych w Redux. Jego główną zaletą jest prostota i elastyczność w zarządzaniu żądaniami sieciowymi i innymi asynchronicznymi działaniami, które wymagają interakcji z Redux Store. Oto kilka kluczowych powodów, dla których warto używać Redux-Thunk:
- Łatwa obsługa operacji asynchronicznych
Redux sam w sobie obsługuje tylko synchroniczne akcje, co oznacza, że nie można bezpośrednio wysyłać żądań API w akcjach Redux. Redux-Thunk rozwiązuje ten problem, umożliwiając tworzenie funkcji akcji, które wykonują operacje asynchroniczne, a następnie aktualizują Store po ich zakończeniu. - Większa kontrola nad przepływem akcji
Dzięki Redux-Thunk możemy wstrzymywać, modyfikować lub anulować akcje w zależności od stanu aplikacji. Na przykład możemy zaimplementować warunek sprawdzający, czy dane są już załadowane, zanim wykonamy kolejne żądanie API, co pomaga uniknąć niepotrzebnych zapytań. - Obsługa efektów ubocznych w jednym miejscu
Redux-Thunk pozwala na scentralizowanie logiki związanej z efektami ubocznymi, takimi jak pobieranie danych, zapisywanie do lokalnej pamięci czy interakcje z API. Dzięki temu logika biznesowa nie jest rozsiana po komponentach, co sprawia, że kod jest bardziej czytelny i łatwiejszy w utrzymaniu. - Prostota w porównaniu do alternatyw
W przeciwieństwie do bardziej zaawansowanych rozwiązań, takich jak Redux-Saga czy Redux-Observable, Redux-Thunk jest stosunkowo prosty w użyciu i nie wymaga nauki dodatkowych koncepcji, takich jak generatory czy RxJS. Jest to szczególnie korzystne dla osób, które dopiero zaczynają pracę z Redux. - Łatwe testowanie akcji i reduktorów
Redux-Thunk pozwala na łatwe testowanie funkcji asynchronicznych, ponieważ możemy testować je niezależnie od komponentów. Możemy także sprawdzać, czy dane akcje zostały poprawnie wywołane i czy stan Redux Store został odpowiednio zmodyfikowany po wykonaniu zapytania.
Podsumowując, Redux-Thunk jest lekkim i skutecznym rozwiązaniem, które doskonale sprawdza się w aplikacjach React korzystających z Redux. Jego prostota, elastyczność i łatwość implementacji sprawiają, że jest jednym z najczęściej wybieranych middleware do zarządzania efektami ubocznymi.
SPRAWDŹ SWOJĄ WIEDZE Z TEMATU redux-thunk
Pytanie
1/5
Alternatywy do Redux-thunk
Alternatywą do Redux-thunk jest Context API, które jest wbudowane bezpośrednio w bibliotekę React. Zapytania asynchroniczne możemy z łatwością tam utworzyć. Praktyczną różnicę zobaczymy dopiero, gdy Context API będzie obsługiwać spory obiekt, w którym będziemy często aktualizować parametry. Może się okazać, że Context API jest wtedy mniej wydajny i zbyt często uruchamia aktualizacje DOM.
Mimo, że Redux jest oddzielną biblioteką to posiada bogatą dokumentację z dobrze opisanymi przykładami. Przykładów dla Redux-Thunk też jest dużo i jest zdecydowanie produkcyjnym rozwiązaniem do utrzymywania stanu aplikacji.
Nasza oferta
Web development
Dowiedz się więcejMobile development
Dowiedz się więcejE-commerce
Dowiedz się więcejProjektowanie UX/UI
Dowiedz się więcejOutsourcing
Dowiedz się więcejPowiązane artykuły
LogTech: Rewolucja w logistyce dzięki nowym technologiom
4 sie 2025
Nowoczesna logistyka przechodzi dynamiczną transformację dzięki innowacjom technologicznym, które zmieniają sposób zarządzania łańcuchem dostaw. Technologie takie jak sztuczna inteligencja, Internet Rzeczy czy blockchain nie tylko zwiększają efektywność operacyjną, ale też poprawiają bezpieczeństwo, transparentność i zrównoważenie procesów.

Czym jest HRtech i jak zmienia zarządzanie talentami?
2 sie 2025
Technologie HR (HRtech) dynamicznie zmieniają sposób, w jaki organizacje zarządzają ludźmi, talentami i rozwojem pracowników. Narzędzia cyfrowe wspierają dziś niemal każdy etap pracy działu HR – od rekrutacji, przez rozwój kompetencji, aż po analitykę i employee experience. Dzięki temu HR przestaje być jedynie administracyjną funkcją, a staje się strategicznym partnerem w budowaniu przewagi konkurencyjnej.
PropTech – technologia zmieniająca branżę nieruchomości
1 sie 2025
Technologia coraz śmielej wkracza do świata nieruchomości, zmieniając sposób, w jaki kupujemy, sprzedajemy i zarządzamy przestrzenią. PropTech, czyli Property Technology, to dynamicznie rozwijający się obszar innowacji, który rewolucjonizuje tradycyjne modele działania w branży.
Czym jest FashionTech? Rewolucja na styku mody i technologii
31 lip 2025
Moda wchodzi w nową erę – erę, w której tkaniny łączą się z sensorami, projektanci współpracują z algorytmami, a przymierzalnie przenoszą się do wirtualnych światów. FashionTech, czyli połączenie mody i technologii, nie jest już wizją przyszłości, lecz realną transformacją całej branży. Dzięki innowacjom zmienia się sposób projektowania, produkcji, sprzedaży i konsumpcji odzieży.
FoodTech w praktyce: Jak oprogramowanie zmienia branżę spożywczą?
30 lip 2025
FoodTech to jedno z najszybciej rozwijających się połączeń technologii i codziennego życia. Innowacyjne rozwiązania cyfrowe coraz mocniej wpływają na to, jak produkujemy, kupujemy, przygotowujemy i konsumujemy żywność. Od inteligentnych kuchni po aplikacje personalizujące dietę - technologia zmienia każdy etap łańcucha żywnościowego.
Jak technologia zmienia zarządzanie najmem? Lease Management Software w branży nieruchomości
29 lip 2025
Rynek nieruchomości dynamicznie się zmienia, a wraz z nim rosną oczekiwania zarówno najemców, jak i właścicieli. W obliczu rosnącej liczby umów, złożonych regulacji prawnych i potrzeby szybkiej obsługi, tradycyjne metody zarządzania najmem przestają być wystarczające. Właśnie dlatego coraz więcej firm sięga po rozwiązania technologiczne, które usprawniają codzienną pracę i zwiększają efektywność. Jednym z kluczowych narzędzi w tej transformacji jest Lease Management Software – nowoczesne oprogramowanie, które rewolucjonizuje sposób zarządzania najmem.
Czym jest Property Management Software i jak może usprawnić zarządzanie nieruchomościami?
28 lip 2025
Zarządzanie nieruchomościami to dziś znacznie więcej niż tylko zbieranie czynszu i podpisywanie umów najmu. W dobie cyfryzacji coraz większą rolę odgrywają narzędzia, które automatyzują procesy i ułatwiają codzienną pracę zarządców. Jednym z nich jest Property Management Software (oprogramowanie do zarządzania nieruchomościami) – nowoczesne rozwiązanie, które zmienia sposób, w jaki zarządzamy lokalami mieszkalnymi i komercyjnymi.
Zobacz wszystkie artykuły