Redux-Saga
2 minuty czytania
Redux-Saga to biblioteka, która pozwala na łatwiejsze zarządzanie asynchronicznymi akcjami w aplikacjach opartych na Redux. Jest to narzędzie szczególnie przydatne w przypadku skomplikowanych projektów.
Redux-Saga jest biblioteką służącą do zarządzania stanem aplikacji. Instaluje się jako middleware do Reduxa podobnie jak Redux-Thunk, ale składnia za pomocą którą się je wywołuje jest inna.
W Redux-Saga został wykorzystany dość stary koncept generatorów, który pojawił się razem z promisami na konferencji JS w 2013 roku, ale do tej pory nie był i nadal nie jest popularnym rozwiązaniem. Wydaje się dość trudny na początku do zrozumienia, ale rozwiązuje wiele problemów w postaci chociażby tzw. Callback Hell, czyli zagnieżdżonych w sobie wielu zapytań zwracających rezultaty.
Słowa kluczowe w Redux-Saga
Redux-Saga w swojej składni wykorzystuje słowa kluczowe, takie jak:
call, put, takeEvery, takeLatest, all
Każde z tych słów kluczowych jest wykorzystywane w funkcji będącej generatorem, zwracającej obiekty zwane Efektami.
Najprostszym przykładem będzie zapytanie API. W tym zapytaniu pobierzemy listę produktów do naszego sklepu e-commerce, tak by komponent, który wykorzystuję zmienną z listą produktów automatycznie się przeładował.
// saga.js
import { call, takeLatest, all } from 'redux-saga/effects'
function* fetchProducts() {
const products = yield call(Api.fetch, '/products')
}
function* actionWatcher() {
yield takeLatest('GET_PRODUCTS', fetchProducts)
}
export default function* rootSaga() {
yield all([
actionWatcher(),
]);
}
// app.js
const sagaMiddleware = createSagaMiddleware();
const store = createStore(
reducer,
applyMiddleware(sagaMiddleware),
);
sagaMiddleware.run(rootSaga);
Działanie Redux Saga składa się z następujących elementów:
1. Tworzony jest store Reduxowy i do niej podłączamy nasz sagaMiddleware
2. RootSaga za pomocą słowa kluczowego all przyjmuje listę innych obiektów saga na które nasłuchuje.
3. ActionWatcher korzystając z takeLatest nasłuchuje na zmiany w akcji reduxowej o nazwie GET_PRODUCTS
4. Komponent korzystając z Reduxa wywołuję akcję reduxową
5. Wywoływany jest generator saga fetchProducts .
Korzystanie z takeLatest jest o tyle ciekawe, że gdy ta sama akcja będzie wywołana ponownie to poprzednia zostanie anulowana. Istnieje wiele innych elementów wbudowanych w Saga, które pomagają zarządzać asynchronicznością takich jak: debounce, throttle, delay.
Zalety korzystania z Redux-Saga
- Jedną z głównych zalet jest łatwość w zarządzaniu skomplikowanymi sekwencjami asynchronicznych operacji. Dzięki zastosowaniu generatorów i efektów umożliwia tworzenie wyrafinowanych struktur zarządzania asynchronicznością, co znacznie ułatwia pracę z danymi, które pochodzą z różnych źródeł, takich jak API lub WebSocket'y.
- Kolejną zaletą jest jego łatwość w testowaniu. Dzięki temu, że logika asynchroniczna jest odseparowana od samej aplikacji, możliwe jest łatwe i dokładne testowanie modułów Redux-Saga, co z kolei prowadzi do większej pewności, że aplikacja działa tak, jak powinna.
- Warto również zwrócić uwagę na skalowalność Redux-Saga. Ta biblioteka jest zaprojektowana w taki sposób, aby umożliwić łatwe dodawanie nowych funkcjonalności do aplikacji, co sprawia, że jest idealna do zastosowania w większych projektach.
- Ostatnią zaletą jest jej elastyczność. Dzięki temu, że biblioteka opiera się na generatorach, możliwe jest tworzenie różnych typów sekwencji asynchronicznych operacji, co pozwala na dostosowanie Redux-Saga do konkretnych potrzeb projektu.
Kiedy warto korzystać z Redux-Saga
Saga wydaje się być dobrym zamiennikiem dla Redux-Thunków i warto spróbować ją samemu we własnym projekcie. Przydaje się w szczególności wtedy, gdy mamy do czynienia ze skomplikowanym interface'm i wieloma akcjami. Słowa kluczowe czyli tzw. saga efekty rozwiązują wiele problemów związanych z asynchronicznością. Potrafią opóźnić zapytania, określić ich maksymalną częstotliwość, anulować zapytanie jak i wiele innych.
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
Mixpanel: narzędzie do zaawansowanej analizy danych
2 wrz 2024
Nowoczesne biznesy przyswajają dane na niezwykłą skalę. Jednak zbieranie danych to tylko połowa bitwy - trzeba je także efektywnie analizować. Tu z pomocą przychodzi Mixpanel, narzędzie kluczowe dla zaawansowanej analizy danych. Pozwala ono na głębokie zrozumienie zachowań użytkowników oraz zachęca do podejmowania decyzji opartych na faktach.
Czym jest over-eager loading?
2 wrz 2024
Over-eager loading, to technika optymalizacji bazy danych, której celem jest minimalizowanie ilości zapytań do bazy. W przypadku over-eager loading, za pierwszym razem pobierane są wszystkie potrzebne informacje, co pozwala uniknąć 'drobnych' zapytań, które mogą spowolnić aplikację.
Pinia: Nowoczesna i wydajna biblioteka do zarządzania stanem w aplikacjach Vue.js
1 wrz 2024
Pinia to innowacyjna biblioteka do zarządzania stanem, specjalnie zaprojektowana dla aplikacji Vue.js. Wyróżnia się na tle innych podobnych narzędzi swoją wydajnością, prostotą i elastycznością. Pozwala na ustrukturyzowanie i skuteczne kontrolowanie danych w Twojej aplikacji. Zapraszam do zgłębienia tematu, by odkryć pełnię możliwości Pinii.
Maze: narzędzie do testowania użyteczności stron internetowych
1 wrz 2024
W dzisiejszych czasach, gdy konkurencja w przestrzeni cyfrowej jest niezwykle zacięta, użyteczność strony internetowej stanowi klucz do sukcesu. Maze jest rewolucyjnym narzędziem, które przeprowadza testy użyteczności, umożliwiając twórcom stron internetowych skupienie się na dostarczaniu najlepszych możliwych doświadczeń dla użytkowników.
Macierz Ansoffa: Klucz do efektywnej strategii rozwoju
31 sie 2024
Macierz Ansoffa jest niezastąpionym narzędziem w planowaniu strategicznym każdego biznesu. Pozwala ona na zrozumienie czterech możliwych ścieżek rozwoju firmy: penetracji rynku, rozwoju produktu, rozwoju rynku oraz dywersyfikacji. Jak wykorzystać to narzędzie, aby z optmalizować swoją strategię rozwoju? Przekonajmy się.
Notion - czyli co to jest i jak efektywnie z niego korzystać?
31 sie 2024
Czy kiedykolwiek zastanawialiście się, jak uniknąć chaosu w organizacji pracy? Odpowiedzią może być Notion, innowacyjne narzędzie do zarządzania projektami i nie tylko. W tym artykule przybliżę Wam, czym jest Notion oraz pokażę, jak skutecznie wykorzystać jego możliwości do efektywnej pracy.
Co to jest Prefetching?
30 sie 2024
Prefetching to technika optymalizacyjna, która może zasadniczo podnieść wydajność strony internetowej przez przewidywanie akcji użytkownika. To jakby serwer 'przygotowywał' potencjalne dane do wykorzystania zanim użytkownik je poprosi–sposób na przyspieszenie ładowania strony.
Zobacz wszystkie artykuły