useOptimistic for Optimistic UI in Next.js Server Actions (+ Revalidate)

แชร์
ฝัง
  • เผยแพร่เมื่อ 24 ม.ค. 2025

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

  • @vickykumargupta605
    @vickykumargupta605 ปีที่แล้ว +5

    Topics like this should be brought to the attention, this was super helpful.
    I would really appreciate if you regularly bring such topics which would optimize the UI and improve the experience.
    One day, you'll reach the height of millions subscribers.
    Good luck.

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

    Will use this at work for sure. Mind blowingly cool! My clients will be happy.

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

      You use unstable experimental canary features at work?

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

      @@codiumyt I have a high enough degree of certainty this is going to be implemented, so it is fine!

  • @loveboat
    @loveboat 11 หลายเดือนก่อน +8

    "Future of UI", aka the past. This was a lot simpler and very standard before serverless and server components you know.

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

    Awesome, man web development is going to get even more fun

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

    Great tutorial 👍👍!

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

    I'm trying to write test for useOptimistic using jest, but it says "TypeError: (0 , react_1.experimental_useOptimistic) is not a function" :(

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

    Thank you for making the docs in video format. I can't read and I can't see. I usually listen to code and instead of writing I sing it

  • @Edgar-pu1lc
    @Edgar-pu1lc ปีที่แล้ว

    But if submitting is success,component rerender twice, yes ? When changed hook, and api after seconds, sorry for my english :)

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

    Have you tried this on a toggle button ? Such as when the user marks a todo item as complete / incomplete. I'm having a tough time getting it to work properly; it would work fine when I toggle the first time, but if I click again before the re-validation, the optimistic update won't come through.
    Your videos are a Godsend.

  • @Shubham-yc6nz
    @Shubham-yc6nz ปีที่แล้ว

    How to use this when we have toggle scenario. My like works find but when I unlike It does the same delay? as I can only push the values and not remove it

    • @Shubham-yc6nz
      @Shubham-yc6nz ปีที่แล้ว

      I did it anyways.

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

      @@Shubham-yc6nz how did u do it?

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

    cool,thx.

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

    In my opinion it is better to use React Query + actions. We can share logic on multiple pages and revalidation is easier.

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

    RevalidatePath will over fetch your database though

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

    thanks!!!

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

    But in my case, I'm always generating the ID in the server, it won't work for such a case, it will make me to create the ID in the client, and that's something that I don't really a fan of. I believe that the server must have the responsibility to work on its own.
    And if I will create a different ID than the one that in the DB and will try to do an action to that specific record, the server won't find it in the DB. Unless I will revalidate the data from the server everytime.

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

    how can I implement removeOptimisticTodo?

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

      I know it's 7 months after this comment, but it would probably look something like this:
      const [optimisticTodos, removeOptimisticTodo] = useOptimistic(
      todos,
      (state, todoId: string) => state.filter((todo) => todo.id !== todoId)
      );
      and you would pass todo's ID to the function
      if you want to have both add and remove with one hook, you would have to implement your own reducer, or... just use useState() and either filter out the todo you want to remove or append the one you want to add in the setter

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

      @@danielk6333 Thanks!

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

    nextjs hook?

  • @Balance-8
    @Balance-8 ปีที่แล้ว

    How do you opt into this?

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

      Just create a new project with npx create-next-app@latest

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

    nb