My Favorite Way to Fetch Data in React

Sdílet
Vložit
  • čas přidán 25. 04. 2023
  • React couldn't care less how you fetch your data. I use React Query to offload so many concerns we normally have when fetching data. Loading state? Graceful error handling? Caching? It's all possible.
    Video links
    React query: tanstack.com/query/latest
    My links
    My GitHub: github.com/joschan21
    Discord: / discord
  • Věda a technologie

Komentáře • 146

  • @Aidorimuhausu
    @Aidorimuhausu Před 9 měsíci +14

    00:04 React Query is a robust data fetching solution that can be implemented in your own React applications.
    02:07 Provide a query client context to fetch data across the application.
    04:10 React Query allows you to fetch data asynchronously and work with it synchronously
    06:12 The data fetched from the query can be of different types
    08:12 Using useQuery for data fetching and caching in React
    10:13 Mutation is used for changing data, while query is used for getting data.
    12:24 Make get requests and dynamically insert post ID in the URL
    14:33 React query allows for graceful handling of success and error states

  • @ninthsun
    @ninthsun Před rokem +5

    Thanks, this was one perfect introduction to react-query in just 15 minutes!!

  • @ifeanachofavour409
    @ifeanachofavour409 Před 10 měsíci +1

    Brooo, I love your videos and you've been a part of my success in past few months. Great stuff man. Thanks

  • @developerpranav
    @developerpranav Před rokem +5

    Making hooks using React Query is killer! Thanks for the awesome tutorial!

  • @Joe-ka
    @Joe-ka Před 8 měsíci

    I saw too many videos about this and this is by far the best one! thank you. liked and subscribed.

  • @kamehameha38
    @kamehameha38 Před rokem +1

    Just discovered your channel through Theo. Loving your content so far

  • @user-wp4zy2fd2f
    @user-wp4zy2fd2f Před 4 měsíci

    Thanks Bro, a perfect video of how to handle data fetching using react-query. waiting for more on react-query, probably part-2

  • @MilindMishra
    @MilindMishra Před rokem +9

    everytime i think of something josh somehow comes up witha tutorial for the same! how do you read my mind! jokes aside, great work pushing out the content, josh! love the work!

  • @whizzbang7520
    @whizzbang7520 Před 11 měsíci

    Exactly what I was looking for. Nice one!

  • @escaper2137
    @escaper2137 Před 9 měsíci

    bruuuuuh
    where have you been all this time
    thank you for all your efforts

  • @nicholassingh138
    @nicholassingh138 Před rokem

    Love your content bro
    Coming from svelte and watching how react works. It hurts my head for sure.

  • @gradientO
    @gradientO Před rokem

    Best introduction to this!

  • @rahimco-su3sc
    @rahimco-su3sc Před rokem

    i really like your content !! tanks a lot

  • @animegeek-011
    @animegeek-011 Před rokem

    React query is amazing i spent a week trying it, and it's really good

  • @michaelmironov3589
    @michaelmironov3589 Před 11 měsíci

    this is so f*in cool because i lost 2 days to figure out how to fetch data with axios and feed it correctly to lightweight charts library, thank you very much!1

  • @EricFernandoMosqueraVelandia

    Great content bro 🍷🗿!! you are de best!

  • @germantellez2710
    @germantellez2710 Před 4 měsíci

    amazing video man thank you!

  • @willxiang25
    @willxiang25 Před rokem

    great video josh ! and it's interesting that you keep looking left and right 😂

  • @alexenax1109
    @alexenax1109 Před 6 měsíci

    Loved this video!

  • @dejanobradovic9723
    @dejanobradovic9723 Před rokem

    Thanks for stunning topic!

  • @storylineteam
    @storylineteam Před rokem +37

    Using react query with axios is a great solution (tanstack also has a great solution for tables). I like to stay away from the Vercel ecosystem as they are forcing everyone to use their platform for deployment, this is why they are making clones of existing packages (swr, router, etc). Also the React Query Developer tools are great!

  • @Pareshbpatel
    @Pareshbpatel Před 6 měsíci

    Very nice introductionto React-Query. Thanks.
    {2023-12-22}

  • @jaroslavhuss7813
    @jaroslavhuss7813 Před rokem +1

    Yeah, btw. thank you for this video. Now I can see this is a better approach comparint to what I am using now. Arghhh... I just need to rewrite the app again :D

    • @joshtriedcoding
      @joshtriedcoding  Před rokem +1

      OH NO ITS A TRAP! 'I just need this one rewrite' is a big trap my man, be very careful. It might end up in a never ending cycle of rewrites

  • @speedster784
    @speedster784 Před rokem

    What API are you using to transcribe the CZcams video that you briefly demonstrated in the video on the site you working on is it a GPT API or some other API??

  • @lopuma1990
    @lopuma1990 Před 11 měsíci

    Hello friend 😊, thanks for your content, I speak Spanish and I have found the best react query and zustand content here, after playing it several times because of my bad English 😂 hehehe, one question, do you have a video of zustand and react query together?

  • @jotaroisdarius1918
    @jotaroisdarius1918 Před rokem +1

    Hey Josh, do you have any idea on how to force a fallback font in NextJS? I had a problem with the original font which triggered the fallback and I actually liked it more than the original one

    • @BuyHighSellLo
      @BuyHighSellLo Před rokem

      just look up what the font is and set that as your default

  • @anonymoussloth6687
    @anonymoussloth6687 Před rokem

    Is this article project open source? Or will you be creating a whole video where you make this app?

  • @mohitsharma-ep9iy
    @mohitsharma-ep9iy Před 6 měsíci

    in react query version 5 , it is written to support old browsers you have to transpile and polyfill yourself. Have you faced this type of issue where react query stopped working in old browsers ?

  • @codingcambodia
    @codingcambodia Před rokem +6

    What state management do you use. It would be great if You can make a video on reactjs react query and state management for authentication.

    • @joshtriedcoding
      @joshtriedcoding  Před rokem +2

      honestly, I came so far just using context, never tried out anything other than zustand. Might be worth looking into tho, heard lots of good about jotai

    • @BenHuxford
      @BenHuxford Před 4 měsíci

      I've been reading that React Query is good for state management. Is this not true?

  • @satejbidvai
    @satejbidvai Před rokem +3

    I am trying to build something using the Next13 appDir. I went through the docs and found the fetch API for data fetching in server side components. So, should I use react-query only for client side components, or for the entire app. I am a bit confused as to when to use what.

    • @brenosonda8496
      @brenosonda8496 Před rokem +1

      I think react-query works only in client since it uses context and hooks,

    • @natalianatalia1734
      @natalianatalia1734 Před rokem

      If u use nextjs it is recommended to use Server side component so react hooks will not work. But imo using nextjs fetching is so simple that i wouldnt bother client side components.

  • @Dhruv-kumar657
    @Dhruv-kumar657 Před 11 měsíci

    i wanted to use next js only for ssr but i don't know ssr. any video possible on it comparing ssr both react and next

  • @indramal
    @indramal Před 3 měsíci +2

    why axios instead of fetch?

  • @codinginflow
    @codinginflow Před rokem

    Bruder. Is your app a startup or just some fun project?
    I also use NextJS + Express but I use SWR

    • @Luka_brx
      @Luka_brx Před rokem +1

      SWR is better option at the moment i would say

  • @pelazas1
    @pelazas1 Před rokem

    helpful, thanks!

  • @jomoc6112
    @jomoc6112 Před rokem

    great content, i never knew i could handle it this beautifully. please teach me how to reFetch the mutation if the data is still not there, maybe i did it wrong im currently trying it on onSuccess because it is still receiving data.

  • @outroddet_6260
    @outroddet_6260 Před rokem +2

    Hey, echt cooles Video. Kannst du mal ein Video darüber machen, wie du genau vorgehst, wenn du nicht NextJS als backend verwendest, sondern dein eigenes mit express? Weil NextJS hat ja von Haus aus schon ein eigenes Backend. Würde mich echt interessieren.

    • @joshtriedcoding
      @joshtriedcoding  Před rokem

      both approaches are quite similar because after all, nextjs serverless functions are a "spin-off" of express. Not sure how I'd package this into a video, thanks a lot for the suggestion though. Will look into it

  • @xdaniels13
    @xdaniels13 Před rokem

    In next.js 13 app folder system, the Provider has to go in the main layout.tsx file, right? someone knows?

  • @chesterrogersjr1737
    @chesterrogersjr1737 Před rokem

    react-query is the 🐐

  • @martiananomaly
    @martiananomaly Před rokem +3

    Finally I can ditch the ugly useEffect + loading state combo.

  • @waleedsharif618
    @waleedsharif618 Před rokem

    Could you create app where is Nextjs in frontend and express in backend ? Tutorial

  • @techlightdev
    @techlightdev Před rokem

    So cool,

  • @Sammysapphira
    @Sammysapphira Před 10 měsíci

    Love the one piece wallpaper

  • @bizmich_
    @bizmich_ Před rokem

    can any one help i have problem with query params i cannot get them before rendering, I am using react-query by it cannot get them initial

  • @waliahmed3035
    @waliahmed3035 Před rokem +1

    Josh can you please make a video of React Query in Next JS server components?

  • @shu3684
    @shu3684 Před rokem

    but this is client-side fetching solution only, right? do you ever use other data fetching methods?

  • @blossomdoom7609
    @blossomdoom7609 Před rokem

    how do you mutate data in nextjs 13

  • @maxime_spinard
    @maxime_spinard Před rokem

    Is it not a better approche if we pass to the hook the api url and the onSuccess and onError functions from the components ? So we can only have two hooks, one for fetching and one for mutations with default onSuccess and onError if nothing has been passed as prop

    • @istvan.design
      @istvan.design Před měsícem

      There is an issue with onSucces and onError (they are not reliable), they actually removed them in the latest react query version.

  • @ardianhotii
    @ardianhotii Před 11 měsíci

    Can you do a video how to use react-query in nextjs 13.4 app router with data fetching in hooks please , I like your videos so much keep going

  • @333ruka
    @333ruka Před rokem +1

    what extension u use for showing the size of a module like that ?

  • @mathiasriissorensen6994
    @mathiasriissorensen6994 Před 10 měsíci

    I have been used useSWR in the past, but this seems really good. How does it work with Next.js and the app folder considering serverside and "use client" ?

    • @yarapolana
      @yarapolana Před 10 měsíci +1

      I just saw the documentation somewhere not in their official docs. Basically you can make use of the functions with “use server” inside or decouple it to an action.ts file

    • @mathiasriissorensen6994
      @mathiasriissorensen6994 Před 10 měsíci

      @@yarapolana Thanks. I’ll see how it is going to work.

  • @SanderCokart
    @SanderCokart Před rokem

    Axios does allow Generics so no need to do As casting

  • @Saltertv
    @Saltertv Před rokem

    I'm struggling a bit to understand how I can use this to retrieve pre-rendered pages using static or server props. This looks like a good choice for client side rendering and fetching.

    • @deiminator2
      @deiminator2 Před rokem +3

      React query is a hook so you can only use it in the react client, not in the next server

    • @denissorn
      @denissorn Před rokem +2

      I haven't watched the video yet, but he's obviously using Next for that. The API is only for fetching data and business logic. I do wonder why didn't he use Next for this, but I have no experience with it, and my guess is, his estimate was that business logic and API are complicated/important enough to justify the use of another server/separate backend.

    • @joshtriedcoding
      @joshtriedcoding  Před rokem +3

      yeah as it's just a hook, this is meant for client use only

  • @tanjungclan3864
    @tanjungclan3864 Před rokem +2

    Josh, are you using state management like redux for all your project?

    • @nada125love
      @nada125love Před rokem

      the same question I want to ask about

    • @tanjungclan3864
      @tanjungclan3864 Před rokem

      @@abhiramsatpute it's mean, we don't need redux, right?

    • @abhiramsatpute
      @abhiramsatpute Před rokem +1

      @@tanjungclan3864 you don't need redux only when you are storing 'Fetch/Axios' data, for other data like toggling dark/light theme, you might need Redux or even better using Context API.

    • @tanjungclan3864
      @tanjungclan3864 Před rokem

      @@abhiramsatpute it's what i do right now

    • @shakilahmed6870
      @shakilahmed6870 Před rokem

      ​@@abhiramsatpute Redux is not only for fetching data and sharing them among other components.

  • @nubian_goat
    @nubian_goat Před rokem

    Josh is hackerman. even with airplane mode on, he have internet.

  • @EduardKaresli
    @EduardKaresli Před rokem +1

    I'd use React Query if my app isn't using Redux, or RTK Query if I'm using Redux, I think both are awesome.

    • @rl6382
      @rl6382 Před rokem

      Why RTK query if using redux?

    • @EduardKaresli
      @EduardKaresli Před rokem

      @@rl6382 Because it is already integrated with RTK (Redux ToolKit), why importing other packages when you already havea query library included in RTK?

    • @MrSadeeq67
      @MrSadeeq67 Před 6 měsíci

      ​@@EduardKaresliRTK Query is really best option if you have Redux in the app

  • @keshawnsmith320
    @keshawnsmith320 Před rokem

    Are you using windows 10 or 11?

  • @anonymoussloth6687
    @anonymoussloth6687 Před rokem

    Hi, I am a beginner and I was confused between isLoading provided by react query and loading pages in-built in next js. What is the difference? do they do the same thing?

    • @antoniors
      @antoniors Před rokem

      react query's loading just gives you a boolean that you can use to conditionally render some JSX based on it like so: return ( { isLoading && Loading...

  • @Zummota
    @Zummota Před rokem

    6:04 how to do this editing trick?

  • @bob_kazamakis
    @bob_kazamakis Před rokem

    I prefer RTK-Query since it also comes for free with RTK state management

  • @guitarplayer1434
    @guitarplayer1434 Před rokem

    where would I house videos and would I use react to fetch them for a video streaming site

    • @joshtriedcoding
      @joshtriedcoding  Před rokem

      upload them to AWS s3 or cloudinary (I prefer s3), then fetch them via a presigned url

  • @nada125love
    @nada125love Před rokem

    Hi josh, can you please make a video about typescript and how can it be useful than JS for beginners with little tutorial

  • @jimshtepa5423
    @jimshtepa5423 Před rokem

    I didn't fully understand what query keys are for? what would not be possible in case query keys are not used? Please don't answer caching wouldnt be possible. I mean in practice how is behaviour of the fetching would be in case query key is not used?

  • @imkir4n
    @imkir4n Před rokem

    HOW'S THE JOSH!!!

  • @thedevminer
    @thedevminer Před rokem +1

    You missed explaining the `mutate`/`mutateAsync` functions that `useMutation` returns.

  • @omarkraidie
    @omarkraidie Před rokem

    I cannot use useQuery in a server component?

  • @timetosleep8055
    @timetosleep8055 Před rokem

    Is the first load js when building the project always so huge when using react query? up to 350kb!

    • @joshtriedcoding
      @joshtriedcoding  Před rokem +1

      no something is definitely not right in your project haha

  • @_bigNPC_
    @_bigNPC_ Před rokem +1

    I’m a very fan of native apis and fetch API tbh, it not hard at all.

  • @ninjagaskin
    @ninjagaskin Před rokem

    Doesnt Nextjs handle the loading and error cases in the respective loading.tsx and error.tsx files? Is there still merit to using react query?

    • @ninjagaskin
      @ninjagaskin Před rokem

      Great videos btw!

    • @joshtriedcoding
      @joshtriedcoding  Před rokem +1

      Thanks man. The loading.tsx and error.tsx is for server side errors and server side loading state. If you fetch data inside a server component, your loading.tsx will show up

    • @ninjagaskin
      @ninjagaskin Před rokem

      Gotcha. Thank you for clearing that up. Would there be a purpose to run this react query in server side requests or is that not possible. Strictly for client side

  • @smotch7533
    @smotch7533 Před rokem +1

    You should reference your recent videos on fetching...I though this was the same video

    • @joshtriedcoding
      @joshtriedcoding  Před rokem

      true, that might be a bit confusing. Its the more in-depth version as a lot of people asked for it

  • @ashish_prajapati_tr
    @ashish_prajapati_tr Před rokem

    react-query is powerful

  • @sinnis_879
    @sinnis_879 Před rokem +1

    hey josh, can we use react query in Next js 13 with the revalidate and cache methods.
    or is it better to just use simple fetch api in nextjs 13
    please reply

    • @censmart9486
      @censmart9486 Před rokem

      At the top of your component write
      export const revalidate = 3600 // revalidate every hour,
      same as using using fetch API {next : { revalidate: 60} }

  • @muneeburrehman547
    @muneeburrehman547 Před rokem +1

    so you love react query ?

  • @carlosalbertocabreraquirog8297

    does react query work on nextjs?

  • @CapzTube
    @CapzTube Před rokem +3

    OnSuccess and OnError for useQuery (not useMutation) will be being removed in React-Query 5 I think

  • @fayez9939
    @fayez9939 Před rokem

    useSWR is lightweight and enough for most of time.

  • @rojka-_-
    @rojka-_- Před 11 měsíci

    awesome

  • @ongkay250
    @ongkay250 Před rokem

    what about SWR ?

    • @joshtriedcoding
      @joshtriedcoding  Před rokem

      as I said, they aim to accomplish a very similar thing

  • @sno-oze
    @sno-oze Před rokem

    onSuccess and onError is deprecated and will be removed in next major verions, interesting

  • @asimalqasmi7316
    @asimalqasmi7316 Před rokem

    First 🎉

  • @llmaboi
    @llmaboi Před rokem +1

    The wording here is mis leading as React Query is not a data fetching client, axioms or fetch is. React Query is a state management tool with implementations for managing query responses.

  • @rudi-batubara
    @rudi-batubara Před 11 měsíci

    use-query + axios = (KB + KB)
    You should learn more about use-query and axios rather then business logic.😂