Vuex 是一个专为 Vue 开发的应用程序的状态管理模式,它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。
Vuex采用类似全局对象的形式来管理所有组件的公用数据,如果想要修改这个全局对象的数据,是可以修改的,但没那么简单,得按照 Vuex 提供的方式来修改,不能自己随意用自己的方式来修改。
使用 Vuex 的好处
- 1、Vuex 的状态存储时响应式的,当组件使用到了这个 Vuex 的状态,一旦它改变了,所有关联的组件都会自动更新相对应的数据,这样开发者省事很多。
- 2、你不能直接修改 Vuex 的状态,如果是个全局对象变量,要修改很容易,但是在 Vuex 中不能这样做,想修改就得使用 Vuex 提供的唯一途径:显示地提交(commint)mutations 来实现修改。这样做的好处就是方便我们跟踪每一个状态的变化,在开发过程中调试的时候,非常实用。
以上两点是 Vuex 状态管理跟使用传统全局变量的不同之处,也是 Vuex 的优势所在。那是不是所有使用 Vue 开发的 SPA 单页应用都适合采用 Vuex 呢?
适用场景
当然也不是,如果你的应用是个小型的应用,组件不多,组件之间的状态依赖不多,关系清晰容易维护,也就是说不同组件之间很少有数据之间的关联的话,那么你大可不必使用 Vuex 来开发。
反之,如果你开发的是较大型的应用,出现多个视图组件共同依赖一个状态,这个状态相当于我们的全局对象数据,其他组件的改动,会影响到它,反之,它的修改也需要更新其他关联的组件,那么Vuex就很适用。比如:商城系统,外卖系统等等。