问题描述
最近使用vuex来管理全局状态,遇到了computed计算state中数据却不生效的问题。
原因分析:
先看vue官网示例:
computed接收的是一个getter函数,但是这个getter函数是懒加载并且有缓存的,当计算属性最终计算的值发生变化才会触发渲染
在变更对象或数组时,旧值将与新值相同,因为它们的引用指向同一个对象/数组。Vue 不会保留变更之前值的副本。
如果想要更新官网给出的解决方案是使用方法,重新渲染发生时再次执行函数
,但是这种在我的业务场景不行
解决方案:
- 计算具体值