1.vuex是什么?
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状
态,并以相应的规则保证状态以一种可预测的方式发生变化。
2. vuex能够帮助我们解决什么问题?
vuex能够帮助我们解决组件之间数据传递或者共享的问题
3. vuex的理解
Vue 应用中的每个组件在 data() 中封装着自己数据属性,而这些 data 属性都是私有的,完全隔离的。
如果我们希望多个组件都能读取到同一状态数据属性,或者不同组件的行为需要更新同一状态数据属
性,
这就需要一个将共享的状态数据属性进行集中式的管理。
这就是 Vuex 状态管理所要解决的问题。
4.vuex使用
1,安装Vuex,npm install vuex --save 或 cnpm install vuex --save进行安装
2,在src下新建一个名为vuex的文件夹
3,vuex文件夹里面新建一个store.js
4,在刚刚创建的store.js引入vue 引入vuex并且使用use Vuex
5,定义数据
6,定义方法
7,实例化 Vuex.store
8,暴露
完整代码如下:
5.vuex的核心
1. state:存储状态。也就是变量;
2. getters:派生状态。也就是set、get中的get,有两个可选参数:state、getters分别可以获取state中的变量和其他的getters。外部调用方式:store.getters.personInfo()。就和vue的computed差不多;
3. mutations:提交状态修改。也就是set、get中的set,这是vuex中唯一修改state的方式,但不支持异步操作。第一个参数默认是state。外部调用方式:store.commit('SET_AGE', 18)。和vue中的methods类似。
4. actions:和mutations类似。不过actions支持异步操作。第一个参数默认是和store具有相同参数属性的对象。外部调用方式:store.dispatch('nameAsyn')。
5. modules:store的子模块,内容就相当于是store的一个实例。调用方式和前面介绍的相似,只是要加上当前子模块名,如:store.a.getters.xxx()。