redux-toolkit VS redux-saga

Compare redux-toolkit vs redux-saga and see what are their differences.

redux-toolkit

The official, opinionated, batteries-included toolset for efficient Redux development (by reduxjs)

redux-saga

An alternative side effect model for Redux apps (by redux-saga)
Our great sponsors
  • SurveyJS - Open-Source JSON Form Builder to Create Dynamic Forms Right in Your App
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
redux-toolkit redux-saga
287 42
10,396 22,506
1.1% 0.0%
9.9 4.0
3 days ago 15 days ago
TypeScript JavaScript
MIT License MIT License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

redux-toolkit

Posts with mentions or reviews of redux-toolkit. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-02-06.
  • Copilot: Weapon For Laid Back Developers
    2 projects | dev.to | 6 Feb 2024
    In my example I am using Redux Toolkit and I got a prompt for actions to login and logout the user. If I need more functions, I can simply start typing the name, and Copilot provides the completion. For instance, in the example, I'm adding a function to update the user. And of course at the end of the file it suggests the exports.
  • Streamlining State Management with Redux Toolkit
    2 projects | dev.to | 16 Dec 2023
    Check out the official documentation.
  • Next.js Weekly #34: StyleX, Self-Healing URLs, AuthKit, Scaleable TailwindCSS, Layouts vs Templates, Faster Next.js Websites [👇 all links in the comments]
    4 projects | /r/nextjs | 10 Dec 2023
    Redux Toolkit 2.0
  • This Month in React Nov 2023 – Redux Toolkit 2.0, Kent v Lee, Prettier bounty
    5 projects | /r/reactjs | 5 Dec 2023
    Redux Toolkit 2.0 is almost here! Hopefully shipping by this weekend :) Migration page
  • Redux Toolkit 2.0: new features, faster perf, smaller bundle sizes (plus major versions for all Redux family packages!)
    1 project | /r/javascript | 5 Dec 2023
    7 projects | /r/reactjs | 5 Dec 2023
  • Redux Toolkit 2.0: new features, faster perf, smaller bundle sizes, and more
    6 projects | news.ycombinator.com | 4 Dec 2023
    I am _thrilled_ to announce that:

    Redux Toolkit 2.0 is LIVE!!!

    - https://github.com/reduxjs/redux-toolkit/releases/tag/v2.0.0

    This major version has new features, faster perf, smaller bundle size, and removes deprecated options.

    It's accompanied by majors for all our Redux family packages

    ## RTK 2.0:

    - a new `combineSlices` method for lazy-loading reducers - Updates to `createSlice` to include a `selectors` field and allow defining thunks inside

    - Immer 10 w/ faster updates

    - Removal of deprecated options

    See the migration guide:

    - https://redux.js.org/usage/migrations/migrating-rtk-2

    All of the Redux libraries now have modernized packaging with full ESM/CJS compat. They also ship modern JS (no transpiling for IE11), which means smaller bundle sizes.

    We've also done byte-shaving work to shrink the bundles (extracting error messages, de-duping imports)

    ## Redux core 5.0:

    - The TS conversion we did in 2019!

    - Action types _must_ be strings

    - `UnknownAction` as the default action type

    - Better preloaded state types

    - Internal subscription improvements

    - Still marks `createStore` as deprecated!

    - https://github.com/reduxjs/redux/releases/tag/v5.0.0

    ## React-Redux 9.0:

    - *Now requires React 18 and RTK 2.0 / Redux 5.0*

  • Blogged Answers: My Experience Modernizing Packages to ESM
    2 projects | news.ycombinator.com | 25 Nov 2023
    Oh hey, that's my post!

    (yes I spend too much time refreshing HN :) )

    FWIW I did end up with a packaging combination that seems to work sufficiently. I never did fix the "FalseCJS" issue that `are-the-types-wrong` is detecting. I played with double-emitting TS typedefs, and the `tsup` tool _does_ actually have support for that now (added by Andrew Branch from the TS team). So it might be more feasible now. But ultimately I decided I was tired of messing with packaging setup and that what I've got is good enough. (hopefully)

    We're actually about to launch Redux Toolkit 2.0 and Redux 5.0 this week, assuming the last couple pieces come together. Here's the latest RCs - you can see the current `package.json` files in there:

    - https://github.com/reduxjs/redux-toolkit/releases/tag/v2.0.0...

    - https://github.com/reduxjs/redux/releases/tag/v5.0.0-rc.1

  • Setting up Redux Persist with Redux Toolkit in React JS
    3 projects | dev.to | 3 Nov 2023
    However, Redux, or pure Redux to be specific, can be quite verbose and boilerplate-heavy. It requires a significantly lengthy setup, which is where Redux Toolkit comes in handy, offering a simplified and more efficient way to set up and manage state in your React applications.
  • 44 React Frontend Interview Questions
    1 project | dev.to | 12 Oct 2023
    State manager is a tool or library that helps manage the state of an application. It provides a centralized store or container for storing and managing data that can be accessed and updated by different components in the application. A state manager solves several problems. Firstly, it is a good practice to separate data and the logic related to it from components. Secondly, when using local state and passing it between components, the code can become convoluted due to the potential for deep nesting of components. By having a global store, we can access and modify data from any component. Alongside React Context, Redux or MobX are commonly used as state management libraries. Learn more Learn more

redux-saga

Posts with mentions or reviews of redux-saga. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-01-04.
  • Main-Thread-Scheduling
    4 projects | news.ycombinator.com | 4 Jan 2024
  • Creating Own Chat GPT
    9 projects | dev.to | 15 Sep 2023
    For the backend, we chose Python, Django Rest Framework. On the frontend, React, Redux, Saga, Sass. Let’s start with the backend, which was managed by Yegor. He writes about the server part of the project himself.
  • Internals of Async / Await in JavaScript
    5 projects | news.ycombinator.com | 1 Sep 2023
    The whole article properly the best explanation of generators I have come across. This quote stuck out:

    > Generators are a special type of function that can return multiple pieces of data during its execution. Traditional functions can return multiple data by using structures like Arrays and Objects, but Generators return data whenever the caller asks for it, and they pause execution until they are asked to continue to generate and return more data.

    Applications of generators? I have only used Redux-Saga[1]. Can't even think of other libraries that use them, but would be interested in learning.

    [1]: https://redux-saga.js.org/

  • Generators in the wild
    3 projects | dev.to | 6 Aug 2023
    redux-saga. The most popular effects library in js
  • I don't get why I should use Redux
    6 projects | /r/webdev | 9 Mar 2023
    Redux can be extended with a lot of other packages. For example with a side effect manager, you can separate side effects from your business logic, help with error handling and in the same process make testing of side effects a lot easier.
  • What Is The Best Name for This Synchronous Function?
    4 projects | /r/learnjavascript | 3 Feb 2023
    Consumer vs. Producer: Check out Redux Saga
  • Front-end Guide
    54 projects | dev.to | 23 Nov 2022
    Your app will likely have to deal with async calls like making remote API requests. redux-thunk and redux-saga were created to solve those problems. They may take some time to understand as they require understanding of functional programming and generators. Our advice is to deal with it only when you need it.
  • Why Would Anyone Need JavaScript Generator Functions?
    19 projects | news.ycombinator.com | 7 Nov 2022
    Hey thanks for the thoughtful response.

    I agree with everything you mentioned here. I'd love to continue to chat with you about how to make testing sagas better.

    If you'd like, it would be great if we could move this convo to https://github.com/redux-saga/redux-saga/discussions/2337

  • What is the best plan to catch data from multiple api calls and display some data
    2 projects | /r/reactjs | 16 Oct 2022
    If there are dependent API calls, you can probably look at redux-saga. It’s one of the best libraries out there to manage the data.
  • [AskJS] Where will I need to write generator functions?
    4 projects | /r/javascript | 17 Sep 2022
    redux-saga makes use of them in really nice way. https://redux-saga.js.org/ That’s where I’ve used them the most.

What are some alternatives?

When comparing redux-toolkit and redux-saga you can also consider the following projects:

zustand - 🐻 Bear necessities for state management in React

react-query - 🤖 Powerful asynchronous state management, server-state utilities and data fetching for TS/JS, React, Solid, Svelte and Vue. [Moved to: https://github.com/TanStack/query]

redux-thunk - Thunk middleware for Redux

rtk-query - Data fetching and caching addon for Redux Toolkit

next-redux-wrapper - Redux wrapper for Next.js

axios - Promise based HTTP client for the browser and node.js

vite - Next generation frontend tooling. It's fast!

SWR - React Hooks for Data Fetching

Immer - Create the next immutable state by mutating the current one

Next.js - The React Framework