--- title: Use Computed Properties for Cached Reactive Derivations impact: MEDIUM impactDescription: Methods recalculate on every render while computed properties cache results type: efficiency tags: [vue3, computed, methods, performance, caching] --- # Use Computed Properties for Cached Reactive Derivations **Impact: MEDIUM** - Computed properties are cached based on their reactive dependencies and only re-evaluate when dependencies change. Methods run on every component re-render, causing performance issues for expensive operations. When you need to derive a value from reactive state, prefer computed properties over methods for automatic caching and optimized re-renders. ## Task Checklist - [ ] Use computed properties for values derived from reactive state - [ ] Use methods only when you need to pass parameters or don't want caching - [ ] Never use computed for non-reactive values like `Date.now()` - [ ] Consider performance impact of expensive operations in methods vs computed **Incorrect:** ```vue ``` **Correct:** ```vue ``` ## When to Use Each | Scenario | Use Computed | Use Method | |----------|--------------|------------| | Derived from reactive state | Yes | No | | Expensive calculation | Yes | No | | Need to pass parameters | No | Yes | | Non-reactive value (Date.now()) | No | Yes | | Don't want caching | No | Yes | | Triggered by user action | No | Yes | ## Non-Reactive Values Warning Computed properties only track reactive dependencies. Non-reactive values like `Date.now()` will cause the computed to be evaluated once and never update: ```javascript // BAD: Date.now() is not reactive - computed will never update const now = computed(() => Date.now()) // GOOD: Use a ref with setInterval for live time const now = ref(Date.now()) setInterval(() => { now.value = Date.now() }, 1000) ``` ## Reference - [Vue.js Computed Properties - Computed Caching vs Methods](https://vuejs.org/guide/essentials/computed.html#computed-caching-vs-methods)