How To Use Next.js 14 Server Actions

Поделиться
HTML-код
  • Опубликовано: 9 янв 2025

Комментарии • 114

  • @3J2A3Y
    @3J2A3Y Год назад +12

    As a beginner, I can say that reading the Nextjs docs is overwhelming but when they get explained - like you did. It makes perfect sense.

  • @creciendotech
    @creciendotech 9 месяцев назад +2

    This is the best explanation I have watched so far, you have earned a new subscriber. Thanks!

  • @belgi76
    @belgi76 Год назад +3

    Perfect explanation about the server actions.

  • @TribhuwanKushwaha-e7y
    @TribhuwanKushwaha-e7y 11 месяцев назад +1

    Hi this tutorial is really explanatory and can be understand well than other video on the same topic. There is a miner suggestion i want to add that it will be more beneficial to have a get or fetch data actions too.

  • @enz1222
    @enz1222 Год назад +1

    Never seen a better explanation than this 💯

  • @TypeScriptTV
    @TypeScriptTV 4 месяца назад +1

    Very nice and concise tutorial! I learned a lot from it. 👍

  • @muneeburrehman547
    @muneeburrehman547 10 месяцев назад

    very useful and explained in super easy way. Much appreciated!

  • @fahdfady6632
    @fahdfady6632 Год назад +2

    Amazing, it all makes sense now.

  • @prashlovessamosa
    @prashlovessamosa Год назад +2

    Thanks for sharing Brett.

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  Год назад

      You are welcome!

    • @dev-akeel
      @dev-akeel Год назад

      Sharing is caring.
      But when I shared something with Brett. Bro got angry at me and is not talking to me now😢

  • @merakli2022
    @merakli2022 Год назад +2

    Well done. Keep up the good work!

  • @skverskk
    @skverskk 8 месяцев назад +1

    Wow. You explained it all. Thx

  • @SriramPrasanth-n9c
    @SriramPrasanth-n9c 9 месяцев назад +1

    Good Video Awesome Explanation

  • @ashimov1970
    @ashimov1970 9 месяцев назад +1

    God bless, Brett

  • @ekchills6948
    @ekchills6948 Год назад +3

    You always know what we need

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  Год назад +1

      Glad I could read your mind

    • @dev-akeel
      @dev-akeel Год назад

      I found my friend the best in the word and while sharing the best thing with him he stopped talking to me and now😢

  • @NOTHING-en2ue
    @NOTHING-en2ue Год назад +1

    now i really understand the server-actions, very well tutorial thanks a lot ❤

  • @HeroKiller-rh6vx
    @HeroKiller-rh6vx 11 месяцев назад +1

    Great video thanks man!

  • @whezboo
    @whezboo 10 месяцев назад +1

    Hi there! Firstly, thank you so much for the informative video on server actions. I've learned a lot from it!
    I just noticed in the code on page.tsx, there's an unused addExpense function. Since we've already separated the form into its own component and created a dedicated action for server interactions, it seems like this function isn't necessary anymore.
    Perhaps we could consider removing or commenting out this function to avoid confusion and keep our codebase clean. Just a suggestion to streamline things further!
    Thanks again for the awesome tutorial! Looking forward to more content from you. 😊

  • @satvik0099
    @satvik0099 Год назад +1

    Your explanations are always awesome. Just waiting for some full-stack videos from you 😁

  • @jpisty
    @jpisty 11 месяцев назад +1

    Thank you so much. Been struggling with the App router

  • @meilyn22
    @meilyn22 Год назад +1

    Best explanation hands down!

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  Год назад

      Thank you so much!

    • @dev-akeel
      @dev-akeel Год назад

      I have no experience explaining anything 😢 so I lost my friend while explaining him something really very important.

  • @dawid_dahl
    @dawid_dahl Год назад +1

    Great explanation. Thank you!

  • @SteelCityEndurance
    @SteelCityEndurance 10 месяцев назад +2

    Hi, this is pretty straightforward but in the end your writing a function that accesses the database. If you write an API, you can reuse the endpoint as needed. aside from not exposing the POST to the client side how does this benefit the developer ? You're writing the function either way, right?

  • @lukyno5751
    @lukyno5751 10 месяцев назад +1

    Really good video!!! Thx

  • @YuuffyLIVE
    @YuuffyLIVE 9 месяцев назад

    Hey Brett, awesome Video.
    How do we go about using server actions for calling external APIs where we have to authenticate ourself with headers (using clientid,secret).
    Do we just use fetch or can we use external libraries like axios inside server actions?
    In a lot of explanations we use forms and call our own database using ORMs like prisma, but never external apis.
    Another thing (more directed towards server components) is that it is often very confusing switching from one to another and use them simultaneously, when you can only use states inside client components or async/await inside server components.

  • @whatdorin
    @whatdorin Год назад +1

    What extension do I need to use for function autocomplete suggestion like you have here? 2:58

  • @kenscode
    @kenscode 8 месяцев назад

    Great video! I am having trouble finding a resource on how to redirect the user to another page after submitting to the database inside a server action. My code is similar to yours but I have a form with a lot of fields. redirect() says it works but isn't working inside a try/catch block and outside of the block says it's unreachable code 😬

  • @blahblahblah-u3m
    @blahblahblah-u3m 11 месяцев назад

    Appreciated. 0:14

  • @ayushshende4290
    @ayushshende4290 Год назад +2

    How can we use server actions client side but outside of form tags, let's say I don't have any input form like calling a server action on click of a add to cart button, and also how to show loading state in that.

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  Год назад

      I recommend using API routes instead of server functions for that and only way to show loading state is with client side code. You will have to refactor code to suit your case

  • @ChrisHaupt
    @ChrisHaupt Год назад +1

    prisMA!!
    thanks for the video

  • @hr94op
    @hr94op 4 месяца назад +1

    Man, thanks!

  • @sagesofsound298
    @sagesofsound298 10 месяцев назад +1

    I wish there was a way to sort of see the cache working in action. Like with react query. Right now we just sort of assume everything works and is safe.

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  10 месяцев назад

      Yea that would be pretty cool but I guess you can test it out by adding new data and make sure you are fetching data by caching and see if the data updates or not

  • @BobbyCatesby
    @BobbyCatesby Год назад

    What setting or extension do you have enabled to see the vertical ruler on the side, showing opening and closing of divs?

  • @heddshot87
    @heddshot87 Год назад +1

    You don't have to place the cursor on the far right to make a new line, just hold ctrl and enter, you can be anywhere on the line. Same goes for new line above with ctrl+shift+enter. 😊

  • @AbdulRauf-n8o
    @AbdulRauf-n8o Год назад +1

    Thanks for this great tutorial.
    I have a question. Can't we fetch data by using server actions without forms like we do GET request using api route?

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  Год назад

      Thanks for watching! And I think you can only user server actions on forms for data mutations. If you want to perform a GET request then you should just use a route handler.

  • @ItsLeonardoGranetto
    @ItsLeonardoGranetto 10 месяцев назад +1

    I haven't found anything about this in the docs, but can you actually access the request object?

  • @usmanshahid1557
    @usmanshahid1557 Год назад +1

    Good work

  • @aburaihan-py4vi
    @aburaihan-py4vi Год назад

    Excellent!!!!!!!!!

  • @Wortkotze1512
    @Wortkotze1512 Год назад

    is there a link to a github repo :) sometimes this helps to see the whole example at the end?

  • @rockbotico
    @rockbotico Год назад +1

    Thanks for sharing!. I have a question. Why does the title text flash when you add the school supplies? Edit: I found the answer in a github discussion, "I just noticed that the jitter is only there in dev mode. After building the project, it's gone."

  • @Sfeclicel
    @Sfeclicel 2 месяца назад +1

    How do you handle errors or server side validation?

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  2 месяца назад

      You can use a package like ZSA which does server side validation. There are other ways as well

  • @cloudagnostic
    @cloudagnostic Год назад +1

    On the form component, could i just import useState instead of useRef to reset the fields? I’m not that familiar with useRef. Great video by the way

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  Год назад

      Thank you! And yes you can use useState hook as well to reset the form.

    • @dev-akeel
      @dev-akeel Год назад +1

      Yes, absolutely useState can be used.
      But it is better to use useRef for better performance, refer to re-rendering in react useState.

  • @protonys
    @protonys 10 месяцев назад +1

    Hello, how will realize form validation?

  • @darioalves7739
    @darioalves7739 8 месяцев назад

    When you add the expense, looks like the page is refreshing, right? that's not good.

  • @nicolascondrea8068
    @nicolascondrea8068 Год назад +1

    Great vid, thank you!

  • @crim-son
    @crim-son Год назад +1

    My main issue with this is that, i can't know if the server action succeeds or fails, what if the user doesn't have a good network?...i have to use a form everytime I want to use server actions, what if i want it on a click of a button?, id rather just stick to creating APIs and making client side requests

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  Год назад +1

      I agree with you, I still mainly use API endpoints and only really user server actions on contact forms at the moment. However, things could always change.

    • @crim-son
      @crim-son Год назад

      I hope Nextjs team sees the struggle with the use of server actions and come up with brighter ideas, its really beautiful not to have to create and API endpoint for every action, but it also comes with consequences@@brettwestwooddeveloper

  • @aguud
    @aguud Год назад

    nice video

  • @techlightdev
    @techlightdev 11 месяцев назад

    Thank you

  • @marroos5440
    @marroos5440 Год назад +1

    Hi, i am self-taught and I've started learning Next.js 13 2-3 months ago, i have learned how to create simple full-stack app, where app communicates to DB via prisma ORM in/api folder's routes. I liked that way, allowed me to separate backend codes from frontend, but now i see Next.js 14 and Server Actions on every corner. What does that mean for me? Should i stop using /api folder way, and start using server actions, or can i still use /api folder way? Thinking of server actions as newer way, as a part of latest version of Next.js, server actions are probably recommended way. It is a big change for me, who did not learn Next.js completely, yet i need to change big part of how i managed db stuff in my app. Thanks to Your video i am starting to understand server actions, thank you. :}

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  Год назад +1

      I would still stick with API folder routes. It is better overall in my opinion anyways.

  • @hulashmahto99
    @hulashmahto99 Год назад +1

    Revalidate tag how to use

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  Год назад

      I talk about how to use the Revalidate tag at 7:26 mark

    • @hulashmahto99
      @hulashmahto99 Год назад

      @@brettwestwooddeveloper revalidate tag not revalidatepath

  • @Vickysingh027
    @Vickysingh027 10 месяцев назад

    That will show error "only plain objects can be passed to the client component"

  • @PeriklesPeriklesoglu
    @PeriklesPeriklesoglu 11 месяцев назад

    thank you

  • @muradqumizakis8428
    @muradqumizakis8428 Год назад +1

    why do you call it prism when your clearly writing prismA (love the video learned alot)

  • @commashalfstrokes7575
    @commashalfstrokes7575 Год назад +1

    github link please

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  Год назад +1

      sorry don't have for this. It's more of a tutorial

    • @commashalfstrokes7575
      @commashalfstrokes7575 Год назад

      @@brettwestwooddeveloper and it would be really helpful if you do tutorial on a large scale project (like may be a million of users ).. like how should we proceed about it. what will be the best practices when we use next 14. how will be the folders structure architecture.. like a boilerplate kinda thing.. I guess nany of us get understanding in small scale app. but get stuck in architecture wise while going for building large-scale application.

  • @VladyslavChapiuk-p4q
    @VladyslavChapiuk-p4q 2 месяца назад

    It is impossible to have rent for 800$. Other than that, nice video. Thank you!

  • @axolotic6981
    @axolotic6981 11 месяцев назад

    Maybe it's easier, but you send more code and other things to the client = more code = more traffic + more insecure

  • @viniciusrangel544
    @viniciusrangel544 11 месяцев назад

    i still dont like this idea, just refetch everything, you can have some weird behaviors.. lets say that i have a "big" system where 2 users or more can add the data at the same time, the refetch will bring the new items which i didnt create.
    the optimistic way where you can just push to your state its better

  • @sebas15689
    @sebas15689 5 месяцев назад +1

    Bro's knoweledge of react : 9.5
    Bro's knoweledge of basic windows: 1
    Lol unless you code in mac or linux I dont understand how is it that you look like my grandma trying to use the computer when moving stuff around the screen

  • @NitinSharma-fh5fl
    @NitinSharma-fh5fl 5 месяцев назад

    bro you look ai generated

  • @therealdevopsintern
    @therealdevopsintern Год назад +2

    Too much over engineering just to use server actions. I don't think I will be using it. Please viewers don't swallow any new release that comes up, just take a little taste of it and throw it out.

    • @berniko4954
      @berniko4954 Год назад

      True, I prefer standart front to back communications with API, mutating data

    • @dawid_dahl
      @dawid_dahl Год назад

      One can really tell you don’t have a clue what you are talking about.

    • @brettwestwooddeveloper
      @brettwestwooddeveloper  Год назад

      I partially agree with you but yea I think overall I will be sticking with API folder routes.

    • @therealdevopsintern
      @therealdevopsintern Год назад +2

      @@dawid_dahl your statement tells you don't know what is happening in the developer community. Server actions is fucked when you are using the same API for mobile app development.

    • @dawid_dahl
      @dawid_dahl Год назад

      @@therealdevopsintern Why don’t you provide some arguments instead of just swearing and acting like an idiot?