Redux - Complete Tutorial (with Redux Toolkit)

แชร์
ฝัง
  • เผยแพร่เมื่อ 28 ธ.ค. 2024

ความคิดเห็น • 420

  • @cosdensolutions
    @cosdensolutions  9 หลายเดือนก่อน +13

    Hope you enjoyed the video! I also have a really cool and unique course that will teach you way more than this video. You'll learn how to build an actual complex project with React. It's called "Project React" and you can find it at cosden.solutions/project-react. Also, I have a free weekly newsletter called "Import React" with tutorials, news, and cool stuff about React! You can sign up at cosden.solutions/newsletter?s=ytc

  • @tallmantek
    @tallmantek ปีที่แล้ว +102

    You're an awesome teacher, i legit paused a complicated redux tutorial i was watching yesterday when i saw your post notification for this one and i'm glad i did. Great work bro

    • @cosdensolutions
      @cosdensolutions  ปีที่แล้ว +4

      Damn, thank you for the kind words that means a lot! Really glad you found this useful ☺️

    • @tallmantek
      @tallmantek ปีที่แล้ว

      @@cosdensolutions you’re welcome! I don’t know if you have tutorials on NextJs but if you don’t pls consider making one. Your style of teaching is really great and easy to follow along🫡

    • @jotasenator
      @jotasenator ปีที่แล้ว

      hey, the same over here

    • @balasubramani9310
      @balasubramani9310 ปีที่แล้ว +2

      @@cosdensolutions
      Hi @cosdensolutions
      @cosdensolutions ,Thanks . As you said , if redux copy the whole state and update the modified proerty in the copied state and replace the while orginal state , my doubt is , do we get performance issue , if our application has more state variable ?

    • @Storkz0re
      @Storkz0re 10 หลายเดือนก่อน +1

      I also impressed how he memoizes, does, and casts things in numerous videos, I'd rank him in a row with Shwarzmuller

  • @licokr
    @licokr 9 หลายเดือนก่อน +9

    Absolutely, amazing. 'Complete Tutorial' is perfect match for your video. You literally talk about everything we can use redux-toolkit in a real project right now. Thanks 👍

  • @MateuszMinder
    @MateuszMinder 11 หลายเดือนก่อน +57

    Tried like 4-5 courses last 2 days trying to understand everything not withing 4 hours long course, and it seems that this one solved all my wonders about Redux. Thank you man, I appreciate that much

  • @gaganyt7861
    @gaganyt7861 ปีที่แล้ว +13

    Literally I am building my tech stack based on your videos
    You teached React query i learned it
    You teached Cypress i learned it
    Now you teached redux with RTK ofcource i will add that too

    • @cosdensolutions
      @cosdensolutions  ปีที่แล้ว +3

      haha damn, great to hear! The next step is to know and understand which tools to choose for which project, as some might be better suited for specific use cases!

    • @gaganyt7861
      @gaganyt7861 ปีที่แล้ว +2

      ​@@cosdensolutionsplease next video about the best tech stack in 2024 frontend+backend+database

    • @AskoldTheFirst
      @AskoldTheFirst 4 หลายเดือนก่อน

      @@gaganyt7861 what about ReactJS/MaterialUI + C#/.Net + MSSQL or MongoDB?

  • @LifeAtMH41
    @LifeAtMH41 10 หลายเดือนก่อน +8

    You have mad teaching skills. You made me understand Redux in just one video. Thanks man.

  • @mouseclicker4955
    @mouseclicker4955 ปีที่แล้ว +10

    This is probably the only video on TH-cam which explains how to use redux toolkit with Typescript clearly. I just subscribed and am looking forward to more of your content in the future!

    • @cosdensolutions
      @cosdensolutions  ปีที่แล้ว +2

      Thank you for the kind words! Glad you find the videos useful ☺️

    • @gubatenkov
      @gubatenkov ปีที่แล้ว

      @@cosdensolutions next video should be "Why you dont need to use Redux in 2024". Even Dan Abramov, one of the creators of redux, writes in his twitter that we almost always should not use redux. And its true. Lol, this video is a waste of time, sorry @cosdensolutions

    • @hasaniqbal233
      @hasaniqbal233 ปีที่แล้ว +2

      @@gubatenkov companies still use Redux, and have applications built with Redux, so you'll need to know it for jobs even if you don't use it in a new application

    • @gubatenkov
      @gubatenkov ปีที่แล้ว

      @@hasaniqbal233hm, u are absolutely right

    • @cosdensolutions
      @cosdensolutions  ปีที่แล้ว +1

      @@hasaniqbal233 still valuable even in new apps. Tons of new projects use it daily. It's a great tool, but only with TK imo

  • @TechMagic204
    @TechMagic204 10 หลายเดือนก่อน +4

    You not only did this perfectly but you even left the name of the vsCode theme you are using in the description. 🙃

  • @toheebajayi1454
    @toheebajayi1454 4 หลายเดือนก่อน +6

    Don’t know redux was so easy until I watched this video. Thanks

  • @yugeshkk3062
    @yugeshkk3062 ปีที่แล้ว +2

    No Extra Talks just straight to the matter , well explained sir, Thanks a Lot..

  • @jahelation8658
    @jahelation8658 10 หลายเดือนก่อน +2

    Thank you man - I love how you give context and make it all seem simple. Other resources turn it into a head fck.

  • @tireksik7193
    @tireksik7193 3 หลายเดือนก่อน

    The best redux tutorial on internet! At first it may sound confusing, but by around 1/3 of the video everything clears up

  • @fullmastrinio
    @fullmastrinio 11 หลายเดือนก่อน +2

    By far the best example, hands down. Very well done. I have not touched Redux since 2019 and this video was just what I needed to get back to it

  • @germoreira1
    @germoreira1 9 หลายเดือนก่อน

    You said that with this video we would understand redux and it would not be necessary to watch more videos. You did not disappoint!

  • @ET_Bermuda
    @ET_Bermuda 10 หลายเดือนก่อน +2

    You definitely got mad teaching skills, man. You really do explain every little thing perfectly. Good job.

  • @justf.c.b8572
    @justf.c.b8572 หลายเดือนก่อน

    that was so clean and smooth man , appreciate your effort

  • @viallymboma9874
    @viallymboma9874 ปีที่แล้ว +4

    There's no difference between his teach skills and that of an Indian teacher:
    Pragmatic
    Straight to the point
    Step by step
    Making eveything make sense to the learn
    Like unveiling a wrap.
    I'm hooking to your channel now henceforth.

  • @someguynamedvictor
    @someguynamedvictor ปีที่แล้ว +1

    Really helpful. Thank you! Im a pretty experienced FE dev who has never used Redux at my previous role(we used zustand and everything else was handled through services) and I have a technical interview tomorrow, they mentioned redux and I was like yowzers I need a refresher. Now I feel like I get it!

    • @cosdensolutions
      @cosdensolutions  ปีที่แล้ว

      Great to hear! Actually filming the zustand equivalent video this week!

  • @killswitch.
    @killswitch. ปีที่แล้ว +2

    I've been waiting so desperately for this...

  • @Retr0_Pr
    @Retr0_Pr 9 หลายเดือนก่อน +1

    You're a fantastic teacher. Thanks for this awesome video!

  • @austinmigchelbrink4938
    @austinmigchelbrink4938 2 หลายเดือนก่อน +1

    Bravo. You lay this out like docs do and provide some foundational term definition and concept explanation before applying. Bravo.

  • @sanhitabiswas1171
    @sanhitabiswas1171 ปีที่แล้ว +3

    too good ...my first redux store i could create just because of you .As offical redux documentation is little difficult to understand . Thanks a lot.

  • @tbyrondouglas1
    @tbyrondouglas1 หลายเดือนก่อน

    Great video! I can't say I won't have to watch this over again a couple of times before it sinks in, but it is one of the best concise explanations of react & redux! Ciao ciao!

  • @shubhamshekhar23
    @shubhamshekhar23 ปีที่แล้ว

    At this point i am now convinced you are a Godsend React teacher ..

  • @maryamblri
    @maryamblri ปีที่แล้ว +2

    This is the best redux tutorial. Explained everything developer need :) Thank you!

  • @mayuripatel3225
    @mayuripatel3225 8 หลายเดือนก่อน +1

    I've seen lots of tutorials but the way you explained everything is just amazing.

  • @wenbinliu6600
    @wenbinliu6600 11 หลายเดือนก่อน +3

    GREAT TUTORIAL BRO!! I was amazed by how can it be so clear for such complex concepts!! I love your speak voice, also love the sound of your keyboard! Everything is just so PERFECT!! Thank you!!

  • @basiorbb3
    @basiorbb3 ปีที่แล้ว +3

    I was just thinking yesterday to add a comment asking you to explain redux. Thank you for what you are doing. Keep it up.

  • @abhisheknavgan6829
    @abhisheknavgan6829 11 หลายเดือนก่อน +2

    thnx buddy! the latest update of redux made all the past tutorials very hard to follow and I was stuck on this for the last 2 days, your video did a fabulous job of explaining the builder❤❤

  • @anastasiiamatiushenko1508
    @anastasiiamatiushenko1508 5 หลายเดือนก่อน

    Incredibly good and clear explanation. I've been struggling to understand Redux for quite some time. Indeed, no need to watch any other videos about Redux Toolkit after yours. I'm happy I could understand everything. Finally! Thank you!

  • @strugglingElds
    @strugglingElds ปีที่แล้ว +2

    Thank you for this one man, I badly need clear explanation like this. Kudos!

  • @Remirured
    @Remirured 3 หลายเดือนก่อน

    Thank you alot. I used to code with Angular and had to learn the redux equivalent. I watched a few videos but all of them are really bad. This video explained it so simple

  • @BeeBeeEight
    @BeeBeeEight ปีที่แล้ว +3

    Thank you for this video. U certainly did explain quite clearly how RTK works and the best thing is, u even included how to work with typescript and thunks, which so far I've not seen other videos do.
    My opinion after watching this, and also after reading what Dan Abramov wrote (what somebody above me said), is that sometimes we will still need redux for the fact that the native Context API does not sufficiently cover all use cases for state management. Therefore knowledge of redux is still good to have in 2023/2024 🙂

    • @cosdensolutions
      @cosdensolutions  ปีที่แล้ว +1

      yeah totally, Redux is still valuable and will be for a long time. There are a ton of new projects choosing to use it daily because it's really good. Imo context isn't good enough to cover most state management use cases. You really need a dedicated library for that!

  • @jebrealaldrani6547
    @jebrealaldrani6547 23 วันที่ผ่านมา

    Thank you for this video. You described redux in a very beautiful way

  • @daniyalsohail2200
    @daniyalsohail2200 ปีที่แล้ว

    Bro you are a gem. We have to protect you at all costs.

  • @ariyoujahan9662
    @ariyoujahan9662 3 หลายเดือนก่อน

    Wow, amazing.
    Truly astonishing.
    It answered all my questions.
    Thank you Cosden

  • @pratikghare_
    @pratikghare_ 2 หลายเดือนก่อน

    Really appreciate the way you made redux easy to understand!

  • @achilles7755
    @achilles7755 ปีที่แล้ว +2

    one of the most straightforward tutorials! Thanks man!

  • @robboerman9378
    @robboerman9378 7 หลายเดือนก่อน +2

    Damn, you took my understanding of Redux from 5% to 90% in one session. Not only that, but by showing the redux toolkit you gave me ideas on how to redo the state of an application I am building! Thanks a lot, subscribed of course

  • @sehejwahla5437
    @sehejwahla5437 11 หลายเดือนก่อน

    Actually the best Redux lesson out there. Goated.

  • @Dalsy97
    @Dalsy97 ปีที่แล้ว +3

    Great video, explained everything in a easy yet straight forward way. Been able to implement Redux for the first time in a simple Todo app just by watching your video. Thanks again!

  • @jankowalski2652
    @jankowalski2652 5 หลายเดือนก่อน

    that was amazing tutorial, I really like the way you explain things, down-to-earth and straight to the point!

  • @gouravkolhatkar3623
    @gouravkolhatkar3623 8 หลายเดือนก่อน

    Best Redux toolkit tutorial, period.

  • @parasmalhotra7633
    @parasmalhotra7633 3 หลายเดือนก่อน

    Great tutorial, gave complete information about the redux, all in one i needed. Well explained and a complete timely guide for redux. Great work bro

  • @papanoelle785
    @papanoelle785 10 หลายเดือนก่อน

    The way I see it, you should have a million subscribers by now. Good job!

  • @MarlonEnglemam
    @MarlonEnglemam 9 หลายเดือนก่อน +2

    great video. I've always liked and tried to use redux toolkit since the first time I came across it! I have one question though, I'm planning to add redux toolkit to deal with states in the react application I'm working on but it's not completely clear how to deal with HTTP responses from the backend services, what I mean by that is: let's picture a scenario where I call a service layer/endpoint from inside the async thunk action, is it ok for me to just return its response back to the JSX component that dispatched that action? or is it better if I simply use its response and deal with it inside the redux slice and use states to update the user interface (with a toast error message, let's say)? (consider that I'm not using RTK query to deal with HTTP requests, instead I'm gonna have a service layer with classes that will receive a axios instance and then make the HTTP calls)

  • @thomasnarkiss6319
    @thomasnarkiss6319 10 หลายเดือนก่อน +1

    Rtk query tutorial will be highly appreciated as well. Thanks!

  • @Ryan-fe2du
    @Ryan-fe2du 5 หลายเดือนก่อน

    This is awesome! From Zero to Hero! Thank you!

  • @bijeeshbalakrishnan887
    @bijeeshbalakrishnan887 3 หลายเดือนก่อน +1

    14:37 where does the counterReducer come from it’s not in the slice

  • @omerkarakas
    @omerkarakas ปีที่แล้ว +1

    Hey Darius. I do appreciate your channel. This video is extremely helpful. Thanks.

  • @TheHiDerr
    @TheHiDerr 10 หลายเดือนก่อน

    The best copilot advert that exists! 👍😁
    I'll definitely buy it 🥰

  • @AvinashKumarNagar
    @AvinashKumarNagar 7 หลายเดือนก่อน

    Thank You :D. It is true, we don't need to watch any other video again! Same was the case for your react router toutorial.

  • @8359s
    @8359s 2 หลายเดือนก่อน

    Thank you. What is the next step after this short course?

  • @Amritbagga-vk6kq
    @Amritbagga-vk6kq 7 หลายเดือนก่อน +1

    Your keyboard so satisfying to hear!

  • @MarcelQT
    @MarcelQT 8 วันที่ผ่านมา

    fantastic tutorial. keen to try redux in my projects!

  • @wallowizzard
    @wallowizzard ปีที่แล้ว +2

    Thanks for the video, Sir. This was very clear and easy to follow. You've now earned yourself a new Subscriber! I'm looking forward to watching other topics you cover around React.

  • @andrewborys4599
    @andrewborys4599 ปีที่แล้ว +2

    Thanks for the tutorial, very helpful!
    You are a great teacher, you explain complex things in simple words!

  • @Rafps3player
    @Rafps3player 9 หลายเดือนก่อน

    thanks a lot for this video. i am getting started with redux toolkit and this was helpful to grasp the basics

  • @yekuwilfred6864
    @yekuwilfred6864 ปีที่แล้ว

    Best Redux tutorial I have come across. 👏👏

  • @webfnatic
    @webfnatic ปีที่แล้ว +1

    Great video! Concept cleared.
    Thank you!

  • @bhargavganesh6496
    @bhargavganesh6496 8 หลายเดือนก่อน

    explained everything in just 30 min
    wonderful tutorial
    thanks

  • @allhailalona
    @allhailalona 4 หลายเดือนก่อน

    Excellent thank you very much for this video!
    I suggest categorizing the video, it takes a while, but saves me as a viewer lots of time watching things I already know...

  • @UnstableInfused
    @UnstableInfused 7 หลายเดือนก่อน

    Thank you! That was fantastic and clearly explained some concepts I've been struggling with for days!

  • @Nothing-xi5dv
    @Nothing-xi5dv 4 หลายเดือนก่อน

    Thanks, cosden, for your valuable video.

  • @santech5669
    @santech5669 ปีที่แล้ว

    I saw ur zustand video, when u said trust me I already trust u lol, really great tutor

  • @shamanFR
    @shamanFR ปีที่แล้ว +2

    Been using RTK for the better part of the year, with it all being a bit hazy in my head, mostly using RTK Query and the caching! You’ve just mind blown me with this basic, but very clear, tutorial. I the spirit of the store and data fetching. Do you think you could make a video on persisting the data? (Unless you’ve already got one on your channel!) thanks a bunch, plus, I no longer feel alone with keyboard typing issues! 🤪

    • @cosdensolutions
      @cosdensolutions  ปีที่แล้ว

      hahaha the keyboard typing!! Yes I might look into persisting the data with redux, I think it's as simple as using redux-persist but might be worth for a tutorial!

    • @yehorsanko9241
      @yehorsanko9241 ปีที่แล้ว

      Within the past year found myself in the exact same situation. ChatGPT helped setting up the RTK but so happy to finally get to understand it fully.

  • @ailint5557
    @ailint5557 7 หลายเดือนก่อน

    One of the rare easy to understand explanation, which also explain what, why and where different Redux methods and hooks should be used and their syntax.
    Can you please make another video about Redux middleware?

  • @jaycekuruvilla8014
    @jaycekuruvilla8014 2 หลายเดือนก่อน

    Very clear explanation..very helpful video..Thanks !

  • @diegomax
    @diegomax 5 หลายเดือนก่อน +1

    Apart from the great explanation, the fact that some people seems to think this "paradign" is cool blows my mind. Am i the only one who thinks this is overcomplicated for no reason ?

    • @cosdensolutions
      @cosdensolutions  5 หลายเดือนก่อน

      it used to be way worse. Try zustand for a simpler solution

  • @rameezh88
    @rameezh88 10 หลายเดือนก่อน

    Thank you very much for the video. Out of many channels that I watch, I find that I get the greatest understanding and value out of yours. Please keep going! Another request is, could you make a video discussing different middleware libraries for Redux such as Sagas and Thunk?

  • @razisraeli1150
    @razisraeli1150 4 หลายเดือนก่อน

    What a great, great video!! Thanks for that! :)

  • @FBC-pc5tv
    @FBC-pc5tv 23 วันที่ผ่านมา

    I love your confidence sir

  • @Shaheer-xs5os
    @Shaheer-xs5os ปีที่แล้ว +1

    Amazing explanation! Thank you for this video sir!

  • @penguinxed
    @penguinxed 6 หลายเดือนก่อน

    Great tutorial bro! Appreciate it so much. Clear and concise.

  • @harag9
    @harag9 ปีที่แล้ว

    Been going through all your videos to learn react and found them really great to follow, left this one as the project I took over at work doesn't use redux, finally got around to watching it. Makes me wonder why we don't use redux as it looks really good, sort of state management (we use context) and useReducer hook rolled into one.
    Just to confirm, when using "useState" vs useRef, the use state forces a redraw but useRef doesn't.... So what is forcing the redraw -- is it whenever you call "dispatch(...)" so just like when using useState.
    Also - great tip at the end, thanks for the heads up on the extension :)

    • @cosdensolutions
      @cosdensolutions  ปีที่แล้ว +1

      Without Redux, useState is causing a re-render and useRef isn't. With redux, it's when you dispatch the action. It then goes to the store which gets updated, and components receive the updates through the selectors if they're listening. This all works through context btw, using the Provider from react-redux, so it's pretty similar!
      I'm not sure why people don't use Redux too much. It used to be a lot more complicated in the past, but now with RTK it's so much better. But sometimes it may be overkill for a project, it depends. I really like it as well!

    • @harag9
      @harag9 ปีที่แล้ว

      @@cosdensolutionsGreat, thanks for confirming that. Not looked at RTK Query yet. just messing around with the basics first :)

  • @karimaBenhssayen
    @karimaBenhssayen 3 หลายเดือนก่อน

    it's so clear, thank you so much

  • @danlabrador
    @danlabrador 8 หลายเดือนก่อน

    Async thunks were always confusing to me. You made it really easy. Thank you!

  • @EnomisArts
    @EnomisArts ปีที่แล้ว +1

    Really clear ! Thank u very much for your work ! :)

  • @mehdiSupp
    @mehdiSupp 11 หลายเดือนก่อน

    17:10 is it that Redux Toolkit is letting you write mutating code and doing some magic behind the scenes, or is it actually that the parameter "state" is a clone of the current state so you can change however you like ?

  • @kalideb-y3y
    @kalideb-y3y 9 หลายเดือนก่อน

    a little confusing, why they are called as "actions" here 18:49 and not "reducers"? As we can clearly see they are defined inside of the "reducers" object so they should have been called "reducers"

    • @cosdensolutions
      @cosdensolutions  9 หลายเดือนก่อน +1

      They are not the functions defined in the reducers, even if they have the same name. They are actions that then trigger those reducere.
      You can see this by the arguments both take. One receives the state, the other is a function you define

    • @kalideb-y3y
      @kalideb-y3y 9 หลายเดือนก่อน

      @@cosdensolutions confusion gone thanks for the explanation. Been watching your videos and sometime back and forth just to ingrain the valuable concepts.. I'd say you're by far the best in explaining things 💪

  • @helenasdiaries515
    @helenasdiaries515 2 หลายเดือนก่อน

    Thank you so much for your tutorials!

  • @mohammaddaudibrahim3501
    @mohammaddaudibrahim3501 5 หลายเดือนก่อน

    Thank you so much for sharing the source code as well, it's very helpful.

  • @andrevenancio
    @andrevenancio 2 หลายเดือนก่อน

    Really nice tutorial. Curious how you handle redux sagas now in the latest server component update where the store needs to be rebuild. Thinking of asynchronous requests for “get user notifications” or something along those lines.

  • @vladmoca
    @vladmoca 7 หลายเดือนก่อน

    This tutorial was amazing! Thank you so much!

  • @sfspmusic
    @sfspmusic 5 หลายเดือนก่อน

    Thank you so much for the video. It was really helpful! I think it would also be cool to hear an explanation of RTK query from you

  • @Manu-ff5vl
    @Manu-ff5vl 11 หลายเดือนก่อน

    I'm glad that i watched ur vedios , it helped me to save lot of time. Good work bro

  • @deepakkashyap6538
    @deepakkashyap6538 ปีที่แล้ว +1

    Great explanation as always 💯

  • @LoayAl-Said-j8p
    @LoayAl-Said-j8p 2 หลายเดือนก่อน

    The first actual thing guys, is that you practice step by step, ok?
    No brain links form and grow from just watching
    Good luck fellows

  • @vinayakpanchal9907
    @vinayakpanchal9907 4 หลายเดือนก่อน

    Amazing amazing tutorial. Thank you so much, God bless!

  • @anjankumarmj01
    @anjankumarmj01 11 หลายเดือนก่อน

    Best RTK explanation video. Thanks brother.

  • @halaalaa4531
    @halaalaa4531 3 หลายเดือนก่อน

    Thank you for this amazing video❤

  • @sunilanthony17
    @sunilanthony17 ปีที่แล้ว

    Thank you, this is exactly what I needed. Your explanation and example is awesome.

  • @RodionAznaurov
    @RodionAznaurov 4 หลายเดือนก่อน

    Thank you. Perfect lesson!

  • @tunde6159
    @tunde6159 7 หลายเดือนก่อน

    Best redux tutorial ever.

  • @kirankothandan5529
    @kirankothandan5529 8 หลายเดือนก่อน

    You are an amazing teacher man❤

  • @dlouhavideacz
    @dlouhavideacz 10 หลายเดือนก่อน

    Promise delivered and I am looking forward to buy and learn some real life project tutorial made by you. Thanks Darius.

    • @cosdensolutions
      @cosdensolutions  10 หลายเดือนก่อน +1

      In about a month I'm launching a course like nothing else. It will teach you everything you need about React and so much more! Stay tuned ☺️

  • @NdubuishiUlenu
    @NdubuishiUlenu ปีที่แล้ว

    I have been struggling for months to make sense of the concepts of store, actions & reducers . Honestly your video here has finally helped me crack the code.I actually was led to your TH-cam channel from your TikTok page.Thanks for the very incisive tutorial.You're a rare breed!!! However I am still struggling to run the Social Echoe app locally.I guess it has to do with dependency version issues??

    • @cosdensolutions
      @cosdensolutions  ปีที่แล้ว

      Thank you for the kind words! I'm really glad you finally understand that! And yes a lot of people have mentioned that with social echo. Not too sure what's going on there 🙁

  • @EliteSurfing-i7c
    @EliteSurfing-i7c ปีที่แล้ว

    Luck to have found you in TH-cam. Thank you very much.

  • @stephennwakasi4631
    @stephennwakasi4631 5 หลายเดือนก่อน

    Very straightforward. Thanks, bro

  • @atifasadkhan
    @atifasadkhan 3 หลายเดือนก่อน

    Thankyou very much!
    what is the extension for that autocomplete ?