Redux Sagas vs Redux Toolkit Query

  Рет қаралды 36,363

Jack Herrington

Jack Herrington

Күн бұрын

Пікірлер: 93
@saakshyadevat9612
@saakshyadevat9612 3 жыл бұрын
Loved this comparison. Rtk query vs react query could also be an interesting discussion topic.
@jherr
@jherr 3 жыл бұрын
You read my mind. Let's see how this one does.
@saakshyadevat9612
@saakshyadevat9612 3 жыл бұрын
@@jherr another suggestion. How these new rest api handling libraries like rtk query and react query compare to using graphql clients like apollo. Thanks for all the effort you put in all your videos jack. :D
@jherr
@jherr 3 жыл бұрын
@@saakshyadevat9612 Yeah, I'm gonna start off with REST and see how that goes and then see if folks are also interested in GraphQL. But if you really want to see this happen. Post about this video on social media! Let folks know you like it and the channel.
@saakshyadevat9612
@saakshyadevat9612 3 жыл бұрын
@@jherr will surely do👍
@alonfai
@alonfai 3 жыл бұрын
I would like to see SWR also compared with all options together : RTK Query, React-Query, SWR and Apollo (both for REST and GraphQL)
@AliAlmahdi
@AliAlmahdi 3 жыл бұрын
You are a great teacher, I remember reading all the documentation when redux was the hype. I wish you did this video back in that time, would have saved me a lot of time. Now, In many apps, similar to this kind, I’d rather use SWR or React-Query for this kind of state management. Rest of state, either Valtio, Zustand or rxjs.
@jherr
@jherr 3 жыл бұрын
I've got some more code ready to go.
@AndyHoebeke
@AndyHoebeke 2 жыл бұрын
@@jherr A comparison with useSWR would be great. However, using Sagas with RTK Query (or others like useSWR?) seems interesting but rarely addresses because.. too "advanced" or simply not recommended (in that case what would better? why? --> great content?) :-)
@raskardev2737
@raskardev2737 3 жыл бұрын
This kind of videos really demonstrate how RTK can simplify and make more with less. Redux Saga is awesome but I think that I'm going with RTK for future projects! Nice video as always, Jack 👌👌
@krishgarg2806
@krishgarg2806 2 жыл бұрын
I think for personal projects, swr or react-query would be better because of better DX.
@SmartWizzard
@SmartWizzard 3 жыл бұрын
Excellent timing, I was looking into these only.
@andreicojea
@andreicojea 2 жыл бұрын
This channel should receive more love ❤️
@aksyonov100
@aksyonov100 3 жыл бұрын
If you want to loose half of your team, introduce redux-saga into your project. The amount of boilerplate code is enormous, complexity through the roof, nobody wants to support that
@_benjimouse_
@_benjimouse_ 3 жыл бұрын
It really feels like sagas are a hang over from class components, classic redux days. In 5 years of using them on a variety of projects, I've never seen anyone do anything with them, other than just call an api, handle the errors, and dispatch result to the store. Why even bother.
@voidreact
@voidreact 3 жыл бұрын
@@_benjimouse_ I feel that for simple use cases like that Redux sagas are way too complex and way too overkill. I'm working on a complex project where there is conditional data fetching based on other data fetched, so it's easier to write and maintain that in a saga than in a react hook or component
@_benjimouse_
@_benjimouse_ 3 жыл бұрын
@@voidreact Yeah, sounds like a good use case for them. I just wish the api was more like hooks...
@Oswee
@Oswee 3 жыл бұрын
Doesn't that depend on the project you are working on? Imagine large scale real-time enterprise app where the eventual consistency is in it's DNA. Sagas is really great and they help to modularize the codebase tremendously. Blaming and running away is for those who are not willing to learn i guess.
@portalplays3760
@portalplays3760 3 ай бұрын
Sagas are great for complex apps that require organised management of side effects. These newer libraries with less boilerplate are missing some key features that sagas give you that you won't realise you need until you are already invested. Be careful following hype trains.
@andrewwall2730
@andrewwall2730 Жыл бұрын
redux-saga is my fav. It has so many features(handling external events, concurrency) and sagas are easily testable and code very clear and concise.
@dgcp354
@dgcp354 3 жыл бұрын
When you said no bs TS you where not joking, great video as always
@narcissisticnarcissus4956
@narcissisticnarcissus4956 3 жыл бұрын
You knowledge is so solid. I feel like you don't have to google around and read documentation. Instead you just know everything from the ground up.
@jherr
@jherr 3 жыл бұрын
I definitely use Google a ton. Thank you for the compliment though.
@zerocodercool
@zerocodercool 3 жыл бұрын
Excellent explanation! I use them both in different packages on a monorepo archiecture.
@idevbrandon
@idevbrandon 3 жыл бұрын
You read my mind! i was studying Redux middlewares and now faced to RTK Query. i was like why there's so many redux sth bla bla haha Thank you so much!
@marouaniAymen
@marouaniAymen 3 жыл бұрын
Thanks for the video, actually we use redux-saga as a middleware for redux in order to manage asynchronous calls, we structured the state as the following { data: null, loading: false, failure: false, error: null }, so we init loading at true inside the saga "function generator" at start then we call the api with axios when data come loading is set to false but in case of error we set loading to false and set failure to true with error message in error. My UI components (spinner, notification toasters) shows and hides when those attributes in the store changes. But I'm thinking to use react-query, I fond it more intuitive and reduces the amount of code w are using with redux and redux-saga. Thanks again for the video, like your channel.
@mahmoudjbour7322
@mahmoudjbour7322 2 жыл бұрын
React-query is a server state only, it won't reflect the UI state, which will force you to write more code and it will be resulted in a buggy code.
@lucasduarte7558
@lucasduarte7558 Жыл бұрын
I like so much yours explanations! Your nature windows are amazing 😍
@YuriiKratser
@YuriiKratser 3 жыл бұрын
Thanks! As always you are on top. It'd be cool to have a similar video with react-query.
@BlinkByteChannel
@BlinkByteChannel 3 жыл бұрын
Can you do a video on optimistic updates with RTK mutations, example, updating or deleting things? I have read the documentation, but there are no simple examples of how to do it right.
@abhvr
@abhvr 3 жыл бұрын
The transition at 0:20 🤩
@xdrap1
@xdrap1 3 жыл бұрын
Redux Saga is advanced because you will deal with generator and everything but the downsize is verbosity; RTK Query is easy and more simple to use but unlike React Query, you don’t have a infinite scroll implementation. At the same time React Query hasn’t a stable persist store implementation like RTK has. So yeah, sadly none of them got all the features so you need to choose which one will fit better for the work.
@wishmeheaven
@wishmeheaven 11 ай бұрын
A copule of years after this visdo was release so I hope the questions are legit, But before - Thank you for another enriching video! - Does anything change in the last couple of years regarding the pros and cons of Saga and Toolkit? - When would you recommend more for async api integration in a full stack app - Saga or Thunk ?
@akashshrestha01
@akashshrestha01 3 жыл бұрын
More videos on RTK plz
@techworld3043
@techworld3043 3 жыл бұрын
. Lol i don't know about React but i still watch your videos for fun 😂
@jherr
@jherr 3 жыл бұрын
Thanks! I try to keep it entertaining!
@mani8586
@mani8586 3 жыл бұрын
Very good session... thanks Jack 👍
@AndyHoebeke
@AndyHoebeke 2 жыл бұрын
I don't find much content about using RTK Query together with Sagas. Sagas call APIs... so.. they could benefit from RTK Query's caching mechanisms and other features... or not? It works, but does not seem so clean to use RTK query inside Sagas ?
@anishbishnoi29xD
@anishbishnoi29xD Жыл бұрын
Which one should we use rtk redux toolkit or redux saga ?
@AndyHoebeke
@AndyHoebeke Жыл бұрын
@AnishKumar-qe4cc Redux Toolkit (RTK) is great. It's a way of using redux with less boilerplate and less chance of bugs 🐛 RTK Query can be used whether you use RTK or not. At work Sagas are used a lot but increasingly we use RTK Query for new parts of the code. You can do a lot with it. The main use case that we still would use Sagas for is when you have requests for many items, some of which may already have been fetched before, and you want to skip fetching them while still including them in the final response. And, when you have several actions triggered by an API query, which can trigger their own API queries.
@anishbishnoi29xD
@anishbishnoi29xD Жыл бұрын
@@AndyHoebekenice, thank you so much. ❤️
@piyushaggarwal5207
@piyushaggarwal5207 2 жыл бұрын
But can we try to use both at the same time somehow? I don't think its possible. Just asking if there is some way to do that.
@ilyastrus4770
@ilyastrus4770 3 жыл бұрын
There is actually not much sense to compare rtk query and sagas. You can easily use both at the same time! Rtk query, react-query, swr, etc are made specifically to solve your typical problems when working with network (caching, bad internet, boilerplate, loading state...). You shouldn't use sagas for these! Instead, it can be used to handle complex flows, when you need debouncing, throttling, cancellation, race conditions etc. Another use case is sending some analytics or writing user preferences to localstorage on various redux actions. In that case you can easily plug in/out these side effects, without changing the main code. Websockets are also playing nice with sagas(with a little help of saga channels). I, actually, haven't use redux much lately, but still in love with some of the sagas concepts. Especially with redux-toolkit, when you don't have to write all that redux boilerplate nonsense
@jherr
@jherr 3 жыл бұрын
Yeah, that's the point I was trying to make at the end there that the two systems cover fairly different ground. Sagas is great at handling complex asynchronous interactions. And RTK Query is excellent at in-depth query management. And you are right they, could make for a great team.
@alejomakevids
@alejomakevids 3 жыл бұрын
Darn, generator functions. Never got a grasp of them may be time to learn about it.
@thehaptiK
@thehaptiK 2 жыл бұрын
very helpful. thanks, Jack!
@cdoremus
@cdoremus 3 жыл бұрын
Nice job! Can you elaborate on what use cases would require redux-sagas? They are way too much cognitive load for my nervous system to use efficiently.
@jherr
@jherr 3 жыл бұрын
Something that would have a lot of choreography between asynchronous events. Maybe a UI that's working with a bunch of microservices directly and needing to make complex sequences of calls.
@szymon8877
@szymon8877 3 жыл бұрын
redux saga is also very straight forward when it comes to testing
@jr-hp7er
@jr-hp7er 3 жыл бұрын
Amazing, was waiting for this :)
@yasser.dev7
@yasser.dev7 Жыл бұрын
Great content as usual thank you!
@RajeshSoni-b8u
@RajeshSoni-b8u Жыл бұрын
Nice Video.. Which VSCode extension was being used for react code completion or snippets?
@wishmeheaven
@wishmeheaven 10 ай бұрын
Thanks for the representation, although... If those are like apples and oranges - why not include an example of how to use them together..?
@andyfifedenim
@andyfifedenim 2 жыл бұрын
I would love for you to do a video on react with variants.. ie a shopping cart with item options…
@arealisticdreamer
@arealisticdreamer 2 жыл бұрын
Great video. What extension did you use to have these code suggestion?
@jherr
@jherr 2 жыл бұрын
GitHub Copilot.
@bysolly
@bysolly 3 жыл бұрын
Loved it. ❤Redux Toolkit Query vs React Query ⚛
@ahmedChebilahmed19chebil
@ahmedChebilahmed19chebil 3 жыл бұрын
currently i m using a combination between redux-saga and redux-toolkit
@saviorhavely
@saviorhavely Жыл бұрын
Very good, thanks for sharing
@navneetkumarsharma9092
@navneetkumarsharma9092 Жыл бұрын
Hi jack, I guess you should update this to use redux toolkit with redux saga
@piyushaggarwal5207
@piyushaggarwal5207 2 жыл бұрын
you are simply jherr
@sunstrike8943
@sunstrike8943 3 жыл бұрын
which extension you are using sir ?
@jherr
@jherr 3 жыл бұрын
GitHub Copilot.
@omdxp
@omdxp 2 жыл бұрын
How does RTK Query create those custom hooks? Anyone ?
@ProgrammingWithOsku
@ProgrammingWithOsku 2 жыл бұрын
This is called functional programming
@omdxp
@omdxp 2 жыл бұрын
@@ProgrammingWithOsku I know what functional programming is and it's my preferred way to write code. However, my question concerns about the details on how RTK create those hooks on the fly (when you type your code even)
@ProgrammingWithOsku
@ProgrammingWithOsku 2 жыл бұрын
@@omdxp Do you speak Arabic?
@omdxp
@omdxp 2 жыл бұрын
@@ProgrammingWithOsku yes
@ProgrammingWithOsku
@ProgrammingWithOsku 2 жыл бұрын
@@omdxp كرر سؤالك بالعربي
@ProgrammingWithOsku
@ProgrammingWithOsku 2 жыл бұрын
I like when you do this , heey its work hahah
@xtinctspecies
@xtinctspecies 3 жыл бұрын
Just shows how awesome life is when using Graphql and Apollo client
@wasaviAr
@wasaviAr 3 жыл бұрын
Great video!
@imchiennb
@imchiennb 3 жыл бұрын
That content is awesome, wish you have stronger to make more videos!
@jherr
@jherr 3 жыл бұрын
Yes!
@CameronRounder
@CameronRounder 3 жыл бұрын
We just set up redux in one our apps where I work and we went with was using connect API over useSelector because of how useSelector re-renders anything connect to the store on any action, not just actions that update the specific state the component is watching. Does RTQ fix this issue, or does it still re-render everything on all actions?
@jherr
@jherr 3 жыл бұрын
Pull down the code and have a look. :)
@damanpreetgrewal
@damanpreetgrewal 2 жыл бұрын
You can create a memoized selector using createSelector and pass it to your getSelectors() declerations
@ayoubbougroune4050
@ayoubbougroune4050 2 жыл бұрын
Thanks for sharing
@archmad
@archmad 2 жыл бұрын
the boilerplate for redux is killing me
@gandalfgrey91
@gandalfgrey91 2 жыл бұрын
It seems that every time you say "HeyHeyyy!!" I spend two hours working out a bug.
@joshuamamroud4821
@joshuamamroud4821 2 жыл бұрын
I feel like the content is great but FWIW it's hard to follow when you go that fast. Half the time the code you add just appears (I'm assuming it's a combination of copy/pasting & video editing) then you move on to the next step. Maybe you can find a way to slow it down and show where the code is coming from rather than having it just appear? No one else seems to have made this comment so it may just be me. Great content though!
@jherr
@jherr 2 жыл бұрын
I've heard that in the past. And the style tends to vary from video to video. Anything with Redux is probably going to be a little more copy-n-pasty though because of the sheer bulk of code and people not wanting to see my poorly type it out.
@dars1816
@dars1816 3 жыл бұрын
I like the style of Redux Saga more, but that's just imo
@jherr
@jherr 3 жыл бұрын
It got me back into generators. Which has been fun. I think most folks have forgotten about them.
@andrejjovanovic3695
@andrejjovanovic3695 Жыл бұрын
gj recommend
Redux Toolkit Query vs React Query
22:12
Jack Herrington
Рет қаралды 110 М.
IL'HAN - Qalqam | Official Music Video
03:17
Ilhan Ihsanov
Рет қаралды 700 М.
BAYGUYSTAN | 1 СЕРИЯ | bayGUYS
36:55
bayGUYS
Рет қаралды 1,9 МЛН
СИНИЙ ИНЕЙ УЖЕ ВЫШЕЛ!❄️
01:01
DO$HIK
Рет қаралды 3,3 МЛН
The Biggest Mistake Intermediate React Developers Make
18:32
Cosden Solutions
Рет қаралды 35 М.
Mastering React Context: Do you NEED a state manager?
37:26
Jack Herrington
Рет қаралды 101 М.
Picking From 20 React State Managers
35:18
Jack Herrington
Рет қаралды 86 М.
FASTER JavaScript In 2025 With Sets
13:13
Jack Herrington
Рет қаралды 16 М.
Redux - Complete Tutorial (with Redux Toolkit)
37:01
Cosden Solutions
Рет қаралды 260 М.
React Query Is (Still) Essential - My Favorite React Library
11:04
Theo - t3․gg
Рет қаралды 160 М.
Fixing Redux/Zustand Re-Renders
28:49
Jack Herrington
Рет қаралды 36 М.
Redux Saga vs Thunk: What should you choose?
14:19
EdRoh
Рет қаралды 34 М.