When You SHOULDN'T Use Computed in Vue

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

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

  • @RomanDawydkin
    @RomanDawydkin 9 หลายเดือนก่อน +4

    Note: it's all changed in Vue 3.4: "a substantial refactor of the reactivity system, with the goal of improving re-compute efficiency of computed properties". "With the post-3.4 optimizations, the callback now only fires if the computed result has actually changed."

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

    Since vue 3 i struggle when to use composable and when not.
    Like everything could be outsourced in a composable (every api request, every state change etc.).
    It is very confusing... 🤕
    Like 80% my logic is in composables...
    Is there any tip or video that could help?

    • @nero1375
      @nero1375 2 ปีที่แล้ว

      did you have so much logic reuse to transfer all those codes into composables?

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

      When the logic is reused, that's when I try to wrap things in a composable.
      I've also seen it used as a way to just structure code so SFCs aren't massive.

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

      @@LearnVue We use it in our company in both mentioned ways. For example, we have different modules in our web app. If we have shared state between the modules, we move it into a composable with global state. If we have module or even SFC specific logic and state, then we still move it into a composable with local state (not shared, newly created whenever the useX is called). As @LearnVue pointed out, this is also a great way to reduce SFC size. By that, our SFCs stay much more readable, since we move it's core logic behind an interface (the composable).

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

    I think the real issue you highlighted is unnecessarily using a computed value as a dependency on another computed value!

    • @butbutmybutt
      @butbutmybutt 2 ปีที่แล้ว

      yes, just use watch functions. but I think it's cleaner with eagerComputed, less code.

    • @fredhair
      @fredhair 2 ปีที่แล้ว

      @@butbutmybutt Oh yeah, it's a nice little abstraction I guess. I don't know that it adds much imo, watch and watchEffect aren't exactly overly complex or verbose! If you're using it a lot then it could make sense.

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

    Great Summary!

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

      couldn’t have done it without a great original blog post and reactivity library 😉

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

    thank you for sharing all the great stuff!

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

    Could you share the Theme name, please? Looks really nice.

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

    didn't know about this. useful

    • @LearnVue
      @LearnVue  2 ปีที่แล้ว

      i thought it was neat too when i read the article - glad you agree :)

  • @abdallah.s1507
    @abdallah.s1507 10 หลายเดือนก่อน

    Thank you for this valuable information

  • @lukmanhakim-hz4jm
    @lukmanhakim-hz4jm 2 ปีที่แล้ว +2

    Very helpful

  • @12generalS237
    @12generalS237 2 ปีที่แล้ว

    This is great, thank you!

  • @furkanulutas
    @furkanulutas 2 ปีที่แล้ว

    Very nice. Thank you.

  • @yanDev
    @yanDev 2 ปีที่แล้ว

    very interesting!
    Thanks

  • @jingzheshan
    @jingzheshan 2 ปีที่แล้ว

    Thanks for sharing!

    • @LearnVue
      @LearnVue  2 ปีที่แล้ว

      Thanks for watching!

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

    "When You SHOULDN'T Use Computed in Vue" - "In a few cases"

    • @jhblack23
      @jhblack23 2 ปีที่แล้ว

      The title is a better clickbait like that 😆

    • @jameswrightson744
      @jameswrightson744 2 ปีที่แล้ว

      @@jhblack23 not click bait, he provides very little reason not to use it

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

      lol the title was too good to pass up.
      i think the use case is 3:46 where you have an expensive operation that relies on a simple computed property is the main summary from a title -> answer perspective.
      the default use and optimizations for computed is still good to handle a majority of use cases, but at least for me - learning about eager computed taught me a lot about the specifics of how vue computed caches and updates.

  • @ilya.degtyarenko
    @ilya.degtyarenko 2 ปีที่แล้ว

    Thanks 💛💙

  • @videolucu5900
    @videolucu5900 2 ปีที่แล้ว

    GOD!!!My broo

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

    This is outdated. Can't replicate it on Vue 3.5

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

      Yeah this is actually the default on 3.4+ blog.vuejs.org/posts/vue-3-4#more-efficient-reactivity-system

  • @MartinMasevski
    @MartinMasevski 2 ปีที่แล้ว

    Interesting 🐱

    • @LearnVue
      @LearnVue  2 ปีที่แล้ว

      I think so too!

  • @Linkplay9
    @Linkplay9 2 ปีที่แล้ว

    just do $: expensiveCalculation(count) and you will be good
    keep calm and use svelte