My Favorite Way to Fetch Data in React

Поділитися
Вставка
  • Опубліковано 2 лют 2025

КОМЕНТАРІ • 151

  • @Aidorimuhausu
    @Aidorimuhausu Рік тому +15

    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

  • @developerpranav
    @developerpranav Рік тому +6

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

  • @EIsenah
    @EIsenah Рік тому +2

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

  • @ninthsun
    @ninthsun Рік тому +5

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

  • @ifeanachofavour409
    @ifeanachofavour409 Рік тому +1

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

  • @codinginflow
    @codinginflow Рік тому +1

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

    • @Luka_brx
      @Luka_brx Рік тому +2

      SWR is better option at the moment i would say

  • @codelodean
    @codelodean 11 місяців тому

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

  • @Joe-ka
    @Joe-ka Рік тому

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

  • @MilindMishra
    @MilindMishra Рік тому +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!

  • @chancefinley2432
    @chancefinley2432 3 місяці тому

    Great Video! Thanks for starting out simple and advancing through how to clean it up.

  • @storylineteam
    @storylineteam Рік тому +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!

    • @joshtriedcoding
      @joshtriedcoding  Рік тому +6

      they really are, cheers man

    • @stexorgamingHDx
      @stexorgamingHDx Рік тому

      D

    • @vickonsscope6477
      @vickonsscope6477 Рік тому +2

      Exactly... Obviously forcing everyone to use their deployment platform..

    • @nidhishsrivastava4868
      @nidhishsrivastava4868 Рік тому

      can we use react query with next js

    • @davidkim2016
      @davidkim2016 Рік тому +3

      @@vickonsscope6477 dont use them then? or better yet, become a good enough developer to not rely on their devx and eco

  • @escaper2137
    @escaper2137 Рік тому

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

  • @michaelmironov3589
    @michaelmironov3589 Рік тому

    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

  • @sosumitoo
    @sosumitoo Рік тому

    Exactly what I was looking for. Nice one!

  • @codingcambodia
    @codingcambodia Рік тому +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  Рік тому +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 11 місяців тому

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

  • @satejbidvai
    @satejbidvai Рік тому +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 Рік тому +1

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

    • @natalianatalia1734
      @natalianatalia1734 Рік тому

      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.

  • @nicholassingh138
    @nicholassingh138 Рік тому

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

  • @gradientO
    @gradientO Рік тому

    Best introduction to this!

  • @willxiang25
    @willxiang25 Рік тому

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

  • @germantellez2710
    @germantellez2710 11 місяців тому

    amazing video man thank you!

  • @tanjungclan3864
    @tanjungclan3864 Рік тому +2

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

    • @nada125love
      @nada125love Рік тому

      the same question I want to ask about

    • @tanjungclan3864
      @tanjungclan3864 Рік тому

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

    • @abhiramsatpute
      @abhiramsatpute Рік тому +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 Рік тому

      @@abhiramsatpute it's what i do right now

    • @shakilahmed6870
      @shakilahmed6870 Рік тому

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

  • @animegeek-011
    @animegeek-011 Рік тому

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

  • @dejanobradovic9723
    @dejanobradovic9723 Рік тому

    Thanks for stunning topic!

  • @mosvel
    @mosvel Рік тому

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

  • @rahimco-su3sc
    @rahimco-su3sc Рік тому

    i really like your content !! tanks a lot

  • @speedster784
    @speedster784 Рік тому

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

  • @mohitsharma-ep9iy
    @mohitsharma-ep9iy Рік тому

    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 ?

  • @anonymoussloth6687
    @anonymoussloth6687 Рік тому

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

  • @jotaroisdarius1918
    @jotaroisdarius1918 Рік тому +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 Рік тому

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

  • @Pareshbpatel
    @Pareshbpatel Рік тому

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

  • @alexenax1109
    @alexenax1109 Рік тому

    Loved this video!

  • @mathiasriissorensen6994
    @mathiasriissorensen6994 Рік тому

    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 Рік тому +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 Рік тому

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

  • @bilalbeny4172
    @bilalbeny4172 15 днів тому

    Thanks! Consider changing the video title to something like, 'Learn How to Fetch Data Easily with React Query' for better clarity.

  • @indramal
    @indramal 10 місяців тому +2

    why axios instead of fetch?

  • @333ruka
    @333ruka Рік тому +1

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

  • @jaroslavhuss7813
    @jaroslavhuss7813 Рік тому +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  Рік тому +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

  • @outroddet
    @outroddet Рік тому +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  Рік тому

      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

  • @anonymoussloth6687
    @anonymoussloth6687 Рік тому

    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 Рік тому

      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 Рік тому +1

    6:04 how to do this editing trick?

  • @kkomjang
    @kkomjang 3 місяці тому

    It is an old way of using react query. Making query options and passing to it as a prop is a better and cleaner way of using it.

  • @shu3684
    @shu3684 Рік тому

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

  • @ninjagaskin
    @ninjagaskin Рік тому

    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 Рік тому

      Great videos btw!

    • @joshtriedcoding
      @joshtriedcoding  Рік тому +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 Рік тому

      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

  • @uncutvideos-l4l7
    @uncutvideos-l4l7 Рік тому

    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

  • @lopuma1990
    @lopuma1990 Рік тому

    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?

  • @maxime_spinard
    @maxime_spinard Рік тому

    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 8 місяців тому

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

  • @timetosleep8055
    @timetosleep8055 Рік тому

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

    • @joshtriedcoding
      @joshtriedcoding  Рік тому +1

      no something is definitely not right in your project haha

  • @nubian_goat
    @nubian_goat Рік тому

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

  • @Saltertv
    @Saltertv Рік тому

    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 Рік тому +3

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

    • @denissorn
      @denissorn Рік тому +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  Рік тому +3

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

  • @keshawnsmith320
    @keshawnsmith320 Рік тому

    Are you using windows 10 or 11?

  • @guitarplayer1434
    @guitarplayer1434 Рік тому

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

    • @joshtriedcoding
      @joshtriedcoding  Рік тому

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

  • @thedevminer
    @thedevminer Рік тому +1

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

  • @waliahmed3035
    @waliahmed3035 Рік тому +1

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

  • @jimshtepa5423
    @jimshtepa5423 Рік тому

    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?

  • @EduardKaresli
    @EduardKaresli Рік тому +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 Рік тому

      Why RTK query if using redux?

    • @EduardKaresli
      @EduardKaresli Рік тому

      @@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 Рік тому

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

  • @bizmich_
    @bizmich_ Рік тому

    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

  • @xdaniels13
    @xdaniels13 Рік тому

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

  • @jomoc6112
    @jomoc6112 Рік тому

    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.

  • @waleedsharif618
    @waleedsharif618 Рік тому

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

  • @chesterrogersjr1737
    @chesterrogersjr1737 Рік тому

    react-query is the 🐐

  • @omarkraidie
    @omarkraidie Рік тому

    I cannot use useQuery in a server component?

  • @sinnis_879
    @sinnis_879 Рік тому +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 Рік тому

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

  • @carlosalbertocabreraquirog8297

    does react query work on nextjs?

  • @bob_kazamakis
    @bob_kazamakis Рік тому

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

  • @nada125love
    @nada125love Рік тому

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

  • @blossomdoom7609
    @blossomdoom7609 Рік тому

    how do you mutate data in nextjs 13

  • @pelazas1
    @pelazas1 Рік тому

    helpful, thanks!

  • @SanderCokart
    @SanderCokart Рік тому

    Axios does allow Generics so no need to do As casting

  • @Sammysapphira
    @Sammysapphira Рік тому

    Love the one piece wallpaper

  • @martiananomaly
    @martiananomaly Рік тому +3

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

  • @ardianhotii
    @ardianhotii Рік тому

    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

  • @CapzTube
    @CapzTube Рік тому +3

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

  • @techlightdev
    @techlightdev Рік тому

    So cool,

  • @muneeburrehman547
    @muneeburrehman547 Рік тому +1

    so you love react query ?

  • @smotch7533
    @smotch7533 Рік тому +1

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

    • @joshtriedcoding
      @joshtriedcoding  Рік тому

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

  • @ongkay250
    @ongkay250 Рік тому

    what about SWR ?

    • @joshtriedcoding
      @joshtriedcoding  Рік тому

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

  • @_bigNPC_
    @_bigNPC_ Рік тому +1

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

  • @ashish_prajapati_tr
    @ashish_prajapati_tr Рік тому

    react-query is powerful

  • @imkir4n
    @imkir4n Рік тому

    HOW'S THE JOSH!!!

  • @VV2sdfds
    @VV2sdfds 4 місяці тому

    bro why do you post your selfie as your cover. like..

  • @llmaboi
    @llmaboi Рік тому +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.

  • @fayez9939
    @fayez9939 Рік тому

    useSWR is lightweight and enough for most of time.

  • @sno-oze
    @sno-oze Рік тому

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

  • @asimalqasmi7316
    @asimalqasmi7316 Рік тому

    First 🎉

  • @VV2sdfds
    @VV2sdfds 4 місяці тому

    bro I'm confused

  • @rudi-batubara
    @rudi-batubara Рік тому

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

  • @rojka-_-
    @rojka-_- Рік тому

    awesome