Vuex
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 + 库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。
安装Vuex
方法一:
在脚手架 创建项目时配置选择vuex的选项系统会自动生成
方法二:npm
npm install vuex
Vuex的概念
vuex中一共有五个状态 State Getter Mutation Action Module
State
提供唯一的公共数据源,所有共享的数据统一放到store的state进行储存,跟data有点像吧
Mutation
更改 Vuex 的 store 中的状态的唯一方法是提交 mutation。Vuex 中的 mutation 非常类似于事件:每个 mutation 都有一个字符串的事件类型 (type)和一个回调函数 (handler)。这个回调函数就是我们实际进行状态更改的地方,并且它会接受 state 作为第一个参数:
Action
进行异步操作
Action和Mutation相似,一般不用Mutation 异步操作,若要进行异步操作,使用Action
原因:
为了方便devtools打个快照存下来,方便管理维护。所以说这个只是规范,而不是逻辑的不允许,只是为了让这个工具能够追踪数据变化
Getter
类似于vue中的computed,进行缓存,对于Store中的数据进行加工处理形成新的数据
Modules
当遇见大型项目时,数据量大,store就会显得很臃肿
为了解决以上问题,Vuex 允许我们将 store 分割成模块(module)。每个模块拥有自己的 state、mutation、action、getter、甚至是嵌套子模块——从上至下进行同样方式的分割:
Vue原理:
Vuex本质是一个对象
Vuex对象有两个属性,一个是install方法,一个是Store这个类
install方法的作用是将store这个实例挂载到所有的组件上,注意是同一个store实例。
Store这个类拥有commit,dispatch这些方法,Store类里将用户传入的state包装成data,作为new Vue的参数,从而实现了state 值的响应式。