Learn React Hooks: useMemo - Simply Explained!

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

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

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

    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

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

      Please add also NextJS to the Project React Course 🙂

  • @abhishekprajapati6849
    @abhishekprajapati6849 ปีที่แล้ว +26

    This was my first and the last useMemo tutorial. I just loved the way you isolated the concept along with a really simple explanation. Thank you!

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

    Timing the "like and subscribe" popup exactly after you explain the solution is genius. I clicked like and it felt good I don't know why lol

  • @mostinho7
    @mostinho7 10 หลายเดือนก่อน +3

    Done thanks clear
    6:50 useMemo memoizes the result of a calculation/ function call until some dependencies change

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

    This could be the best useMemo tutorial I've seen. And I've seen a lot. Almost too many. 😂 Oh, and I love that you keep rounding 29.999.999 to 29 million. Made me chuckle every time... 🤗🤗

  • @RichReflectionz
    @RichReflectionz ปีที่แล้ว +23

    As someone still new to react and web dev in general, this is awesome, the main hooks I’ve been using have been useState and useEffect. Would be great to see one about useRef too :)

  • @JoshuaMusau
    @JoshuaMusau 5 วันที่ผ่านมา

    So articulate and concise. God bless you

  • @sahasrabhujaneuron5975
    @sahasrabhujaneuron5975 ปีที่แล้ว +7

    I've been struggling with this concept, but this video really made it easy and simple to understand. Many thanks!

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

    I am so happy that I got landed to this channel. So concise, loving it.

  • @bhavikpatel2007dx
    @bhavikpatel2007dx 28 วันที่ผ่านมา

    Perfectly explained.. Simple, Clear and Straightforward.. ThankS

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

    Im enrolled in a couple of intermediate and advanced react courses.. even bought a couple of books.. But man, your vids are waaay better and so amazing! clear and concise!!!! i wish you had a full on intermediate/advanced react course. i would gladly pay for that!
    Thank you so much for existing!!!

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

      I'm just about to launch a course that has 2 parts. The first part is more beginner, the second is more intermediate/advanced ☺️ if you get it when it launches you get both for the price of one

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

      Will be sure to do so!! thank you! :D @@cosdensolutions

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

    No one has ever articulated this topic so well. Because it's simple yet confusing. Also I was tired of watching premium full blown course about shopping cart app with tailwind and what not, all to explain the few key concepts hardly for 5 mins which eventually gets buried somewhere in the middle. Thanks for the short and sweet content.

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

    The best useMemo explanation I've seen.

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

    Thank you. You are a great teacher and presenter!

  • @Ahamedmukshithm
    @Ahamedmukshithm 10 วันที่ผ่านมา

    bro you are a react monster

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

    Hey, i really like your way of explaining. I bought an online course on React, but sometimes I just don't get it on the course, and your videos make it super duper clear for me. Thank you for your job, wish you all the best, and I hope some day you are going to have 500k subs on youtube.

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

      thank you for the kind words! I'm also working on a course by the way, will have this teaching style and a really well thought out plan that I haven't seen done in another course before! Coming in a couple of months

  • @erhan.emrah.fırat
    @erhan.emrah.fırat หลายเดือนก่อน

    Very clean explanation! Thank you!

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

    This guy is the best teaching react stuff

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

    Man this video is gold! Thank you! Your useEffect video is also the best I've seen. Now I've decided that I'm gonna watch all your videos!

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

    After watching 3 of your videos I have learned more than reading 3 books on React. Your videos are exceptionally clear. Thanks

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

    Loving your breakdown of the react hooks. thanks for sharing

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

    Finally understand this hook after lot of stuggle !!

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

    It was great. I didn't understand useMemo while I had read many articles about it but this video was very useful. now I know its logic and usage. Thank you

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

    Great tutorial! Thank you! I feel confident using useMemo now!

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

    Best explanation ever. understand in one go.

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

    You have the best tutorials channel 🙌🙌🙌🙌

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

    Wow... perfectly explained man, Thanks.

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

    thank god i stumbled upon your channel..i am learning about all the hooks that react has to offer through your channel..i am loving the clear explanations that you provide..not a single dull moment in the video! kudos to you sir! love you!!!

  • @bittukumar-oc1vv
    @bittukumar-oc1vv 2 หลายเดือนก่อน

    Thank you so much for this lecture.

  • @hoangtran-ek8mn
    @hoangtran-ek8mn ปีที่แล้ว

    Ohhh mannn. Why are you so good at teaching? Thank you so much!!!

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

    Thank you very much for the easier explained concepts. I'm watching your videos to understand my lessons better. Both compliment each other well.

  • @TahaAli-k6l
    @TahaAli-k6l ปีที่แล้ว +2

    Hi sir, I am grateful that I landed here and learn some valuable concepts of useMemo, I have a question that on 11:30 minute you added the count as a dependency array, now when a count changes that computation will run again, then how the usememo is beneficial here, let me know please?

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

      The useMemo is not to prevent a re-render, but rather control when it happens. In that example we did indeed invalidate what we did by adding count, however that's necessary. Our memo depended on count so we had to provide it. The benefit lies when we add a new state variable that is not related to that, then useMemo won't re-render when that changes.
      So again, we're not trying to prevent a re-render, but rather control when it happens and only have it happen when absolutely necessary, otherwise return the memoed value

  • @LauraDuranVelazquez-md4ot
    @LauraDuranVelazquez-md4ot 6 หลายเดือนก่อน

    Thank you for explaining these concepts so simply! Love your videos.

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

    Very good explanation 👍🏽

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

    It's definitely the best explanation I've ever seen. Thank you very much!

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

    Made me rethink the way I was seeing this hook. Thanks

  • @wow-edu-and-dev
    @wow-edu-and-dev 2 หลายเดือนก่อน

    Great explanation! Thank you

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

    Thanks for this video 👍👍👍 really good way that you explain .
    I am lazy person who understand only if simplify way to explain of context and you did it 😜🤗. Good job..!😊

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

    that is the perfect fundamentals . it was very efficient to understand the how important useMemo . thx :)

  • @AnnaHuang-v9i
    @AnnaHuang-v9i 10 หลายเดือนก่อน

    the best video explains useMemo!! thank you so much!

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

    Love your explanations, you have made react a lot simpler.

  • @AsmaaRefaat-h8c
    @AsmaaRefaat-h8c 9 หลายเดือนก่อน

    you are THE BEST to explain!

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

    Really its a Last Usememo video for me🥰🥰🥰

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

    Really useful tutorial. Thanks for being so helpful!

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

    dude you're awesome. Thank you so much for your explanations, now I guess I don't need to watch other videos about react hooks :)

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

    I like your tutorial very short and will explain.
    Thank you so much 😊😊

  • @WaseemAhmad-mf3wh
    @WaseemAhmad-mf3wh 9 หลายเดือนก่อน

    Thank you for your clear explanation ❤

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

    this was a perfect explanation - thank you!

  • @pcnerd5994
    @pcnerd5994 29 วันที่ผ่านมา

    Thanks, this is very helpful!

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

    So simply explained! wow, amazing

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

    every tutorial of cosden solution is last tutorial ur gonna watch - Fr ✌✌

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

    the most clear explanation!

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

    Amazing amazing amazing explanation bro . ♥️♥️♥️♥️♥️. Plss do a javascript series also

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

    that was very helpful, thank you for clearing the confusion

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

    Simply explained indeed, Thank you.

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

    Thanks, Alot Man. Glad i picked your video first now i don't need to watch another video on this.

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

    Best tutorial for useMemo!

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

    Great video, thanks for this, I'll have to look at implementing this now.

  • @isaac-9185
    @isaac-9185 ปีที่แล้ว +1

    Really well explained, thank you. Also mind dropping a list of most common cases that you would use useMemo for?

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

      I would only use it when there's an expensive computation to make, or when I want to prevent this from causing a expensive child component to re-render

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

    Hi, your way of teaching is very easy to understand and helps me learn more concepts. Please make a video on Reactjs Forms as well.. it would really help me understand forms better. Thanks for making learning so easy and effective.

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

    Great video I just begin my react js journey and can easily understand the concept

  • @ShannonSimonCherry-b7t
    @ShannonSimonCherry-b7t ปีที่แล้ว

    So good! You explained it perfectly!

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

    Wonderful !! 👏 I subscribe right away !

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

    so useMemo is fairly similar to useEffect? but useEffect is called when the page is loaded and/or for some dependencies?

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

    Nice tutorial, thanks!

  • @AyushGupta-kp9xf
    @AyushGupta-kp9xf 8 หลายเดือนก่อน

    Nice explanation, appreciate that. Btw dude how do you spam that fast!

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

    Great explication bro. Thank you very much

  • @flux2956
    @flux2956 4 หลายเดือนก่อน +1

    For all the new react developers watchng this video, you wont need usememo, usecallback, and memo hooks again. React now has it's own compiler which will do this for you automatically.

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

      yes but good luck finding a job where they use cutting edge React. Even after 19 useMemo will still be important. It'll be a while before it truly goes away

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

    Ohh man nicely explained 🎉❤

  • @Onto.walking
    @Onto.walking 3 หลายเดือนก่อน

    Premium explanation

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

    great explanation, thank you very much!

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

    Once again great tutorial...

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

    Love it the way you explained everything single detail, Can I also use useMemo with autocomplete with fetch?

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

    all your video is awesome keep it up ,make small project which make use of the all hooks how to use in company level or share some difficult situation of it when to use which hooks use it will be great help

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

      Currently in the process of making a full on course with exactly that!

  • @acm.marques
    @acm.marques 2 หลายเดือนก่อน

    great!! video man

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

    This video helped me a lot.

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

    Great videos. 1 question though, when you have count and items in the hook, why doesn't that lag as it seems like the items are being looped each time count changes?

  • @AbsolutePain
    @AbsolutePain 11 หลายเดือนก่อน +1

    Hey cosden, we can achieve the similar results using useEffect ? so how do we identify when should we use memo ?
    // Use effect equivalent:
    import { useState, useMemo, useEffect } from "react";
    import { data } from "./utils/data";
    const Counter = () => {
    const [arr] = useState(data);
    const [selectedValue, setSelectedValue] = useState(0);
    useEffect(() => {

    const val = arr.find((elem) => elem.isSelected);
    setSelectedValue(val);
    }, [arr]);
    const [count, setCount] = useState(0);
    return (

    Count:{count}
    setCount(count + 1)}>+1
    selectedValue : {selectedValue.id}

    );
    };
    export default Counter;
    Thnaks for the video. Can you make a complete project in react with best practices. Thanks.

    • @cosdensolutions
      @cosdensolutions  11 หลายเดือนก่อน +4

      So while your example works, it's not the recommended approach. The way you have it, you have an extra state variable that you have to manage and a whole useEffect to manage it. If you do it like I showed in useMemo, then selectedValue automatically gets re-computed when the array changes, and you don't have to do it yourself. That's why it's a better approach.
      There are a lot of times where something shouldn't be done with an useEffect even if it can, just because it introduces an extra dependency you have to manage and keep up to date. Also, your example creates an extra render cycle in the component which is unnecessary

  • @ProfessorRagna
    @ProfessorRagna 9 วันที่ผ่านมา

    How can we realize potential performance optimizations not just from a noticeable UI issue, but from the browser or React DevTools? Would love a similar video to this that discusses seeing the issue in the devtools and fixing it afterwards in order for us to understand how to properly debug performance issues like this.

  • @Viva-07
    @Viva-07 10 หลายเดือนก่อน

    Awesome...very well explained

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

    Really great video. I have few questions if u don't mind.
    What are the differences between useMemo and useEffect ? Not talking about syntax or the option return function.
    Instead of using useMemo in this case, you can use useEffect and put items as dependencies.
    useEffect(()=>
    {selectedItems = item.find(item=> item.id)},
    [items]})
    Re-computation only triggered once items is changed, and instance is destroyed to create a new one right? Same as useMemo?
    So why useMemo instead of useEffect?
    Is it linked to memory usage or am i missing something?
    Thank you

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

    Can we use multiple use effect in one component

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

    Super cool video. What is your Vs code theme

  • @MuhammadRidwan-kq4yw
    @MuhammadRidwan-kq4yw 6 หลายเดือนก่อน

    youre an react angel haha,awesome bro,thank you

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

    awesome explanation, thanks

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

    Hi, I’m new to react and your videos are really helpful.
    I have two questions:
    1. In the last specific scenario, is it really necessary using useMemo? I mean, the only cause of rerender is when count changes, so useMemo would compare every render the dependecies.
    2. What is the differences between useMemo and useCallback?

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

      1. In the context of the video, no it isn't. But the goal was to show you how it works!
      2. useMemo returns a value, useCallback returns a function. They are the same otherwise!

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

      Oh, that’s right! Really thanks 😊

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

    what is difference between use Memo and use Effect ????

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

      useMemo works on the memoization concept. That means it stores the result of a function call based on the parameters passed, ex. a sum function where you pass 2 and 2, it will always return 4, so it will store that if you pass 2 and 2 it will directly return 4 instead of actually calculating 2 + 2.
      useEffect just simply runs on re-render

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

    do you still need useMemo for the case with === count?
    what is the sense of useMemo in this case if selectedItem should be recalculated when you click the button? prevent recalculation when page is rerendered, but items and count are same?

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

    Great Explanation, thank you. I have 1 doubt. If I use useState to store the value of selected items and changed its value only when there is change in the dependency array of the useEffect hook, then will it produce the same result? If yes then what is the difference between the two ?
    function Demo({}: DemoProps) {
    const [count, setCount] = useState(0);
    const [selectedItem, setSelectedItem] = useState(0);
    const [items] = useState(initialItems);
    useEffect(() => {
    const temp = items.find((item) => item.id === count)
    setSelectedItem(temp)
    }, [items])

    return (

    Count: {count}
    Selected Item: {selectedItem?.id}
    setCount(count + 1)}>
    Increment


    );
    }

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

      So first of all in your example you're missing `count` in your dependency array. You want that useEffect to run as count changes, as well as when items changes.
      Second of all, that code is equivalent, but now you have an extra piece of state + the hook that keeps it in sync. The way I showed in the video is better because the "sync" happens automatically.
      That approach is better because it has less code (one less hook) and less responsibility (selectedItem is auto updated through `useMemo` without manually having to do anything)
      So you're basically doing the same work, just with extra dependencies, which isn't ideal 😁 best to keep things simple and automatic

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

      was thinking the same thing glad to have found this exchange in the comments

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

      Thank you both for asking and answer. I'm about to ask the same but got the point here.

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

    But when you add count to the use memo dependency array, are you not now doing the find again on every click? Oh I guess this isn't a long running task now as its not searching through the whole array any more. But, doesn't that negate the reason to add useMemo in the first place?

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

      Yep it does, but that's what you want. You don't want to prevent a re-compute, but rather control when it happens. You need the count to perform that operation so there's no way around it. However if you added a new state variable and changed that, then it wouldn't re-compute. It would without useMemo. That's the goal, to control and only when needed re-calculate!

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

    Great explanation!

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

    Great! i still wondering if i use useMemo hook to memo a component then render that component inside component as a variable. Is it oke, thank you ?

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

      Yes that should be fine in theory!

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

      Thank you@@cosdensolutions

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

    doesn't adding 'count' as a dependency recalculates selectedItem on every click on increment ? thus you still have the problem if you spam increment ?

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

      Yes it does. The goal isn't to make things never change, but rather control when they change and prevent unnecessarily changing. Of course this code here is slow by default, I did that to show you useCallback and how it works.
      In this case, if you have to use count and that causes a problem, then maybe it's time to rethink the component and move some things around to avoid that

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

      You can use an object or a Map for items where the keys are the ids. This would allow you to look up items in constant time (O(1)) by simply accessing the item via its id.

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

      @@saadchraibi6712 explain what you are saying pls more in detail with example that could be helpful why would using key be helpful here?/

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

    What is the difference between useMemo and useEffect? If we wrap the selectedItem function inside a useEffect like-
    useEffect( ( )=>{
    const selectedItem=items.find((item)=>item.isSelected)
    },[items ] )
    then it's serving the same purpose.

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

    Thank you, great explanation

  • @nitin-code-comedy
    @nitin-code-comedy 2 หลายเดือนก่อน

    what happens if you remove the dependency array completely in use Memo?

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

    Well explained Thank you very much.

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

    perfect tutorial

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

    I'm new to React and i'm asking if we could solve this probleme using useEffect Hook , by passing the "items" in the dependency Array ?

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

      Nope

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

      Use effect will compute the value again where as use Memo returns the computed value

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

      ​@@kanieseiya4134 i dont get it ??
      UseEffect is also will run first when the comp in intialzed and only if "items" array changed ??

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

    Nice explanation