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
Kotlin Multiplatform: Czym jest i jak efektywnie go wykorzystać?
15 maj 2025
W świecie programowania, Kotlin Multiplatform (KMP) zdobywa coraz większą popularność. Jest to unikalne rozwiązanie, które umożliwia tworzenie współdzielonego kodu dla różnych platform. Stawiając na unifikację, KMP otworzył nowe możliwości dla deweloperów. W tym artykule przyjrzymy się bliżej temu narzędziu, omówimy jego kluczowe cechy oraz przykładowe zastosowania w praktyce.

AEO - Nowa epoka SEO w erze wyszukiwarek internetowych opartych na odpowiedziach
14 maj 2025
AEO, czyli Answer Engine Optimization, otwiera nowy rozdział w obszarze SEO. Era wyszukiwarek internetowych skoncentrowanych na dostarczaniu konkretnych odpowiedzi na pytania użytkowników przemienia dotychczasowe strategie optymalizacji. Jak sprostać nowemu wyzwaniu, na które stawiają nas nowoczesne technologie? Poniższy artykuł odsłoni tajniki efektywnego AEO.
Qwen – zaawansowany model sztucznej inteligencji
13 maj 2025
Sztuczna inteligencja rozwija się w błyskawicznym tempie, a kolejne modele językowe wyznaczają nowe standardy w przetwarzaniu informacji. W tym dynamicznym krajobrazie pojawił się Qwen – potężny, otwartoźródłowy model AI stworzony przez Alibaba Cloud. Dzięki swojej elastyczności, wysokiej jakości i dostępności, Qwen szybko zyskał zainteresowanie zarówno wśród deweloperów, jak i firm technologicznych. Czym dokładnie jest Qwen i dlaczego warto się nim zainteresować? Przyjrzyjmy się bliżej.
Pulumi: Nowoczesne podejście do Infrastructure as Code
13 maj 2025
Pulumi, narzędzie do zarządzania infrastrukturą w kodzie, łączy siłę języków programowania z elastycznością infrastruktury jako kodu (IaC). Podejmuje wyzwanie w dziedzinie DevOps, definiując infrastrukturę przy użyciu najpopularniejszych języków. Przeczytaj, aby dowiedzieć się, dlaczego warto zainteresować się Pulumi.
Pełny cykl tworzenia aplikacji - end-to-end development jako klucz do efektywnych i jakościowych projektów IT
12 maj 2025
Pełny cykl tworzenia aplikacji, zwany inaczej end-to-end development, staje się coraz bardziej popularny w IT, pełniąc kluczową rolę w dostarczaniu efektywnych i jakościowych projektów. Zrozumienie i udoskonalanie tego procesu może znacząco przyspieszyć i ulepszyć prace programistów.
Lunacy: Edytor graficzny dla designerów UI/UX
11 maj 2025
Lunacy to rewolucyjne narzędzie dla projektantów UI/UX, które za cel ma ułatwić i przyspieszyć proces tworzenia atrakcyjnych, intuicyjnych projektów graficznych. Oferując szereg unikalnych opcji i funkcji, Lunacy pomaga w realizacji kreatywnych wizji na najwyższym poziomie. Oto kilka powodów, dla których warto przyjrzeć się bliżej temu edytorowi.
Strona internetowa wizytówka – co to jest i komu się przyda?
10 maj 2025
Strona wizytówka w sieci, czyli prosty, jednostronicowy portal internetowy prezentujący podstawowe informacje o Twojej działalności, osobie czy produkcie. W dzisiejszych czasach wystarczy kilka prostych kroków, aby stworzyć swoją stronę wizytówkę. Jesteś ciekaw jak to zrobić? Zapraszamy do lektury.
Zobacz wszystkie artykuły