1.Vuex是什么?vue
学院派:Vuex
是一个专为 Vue.js
应用程序开发的状态管理模式;集中存储和管理应用的全部组件状态。框架
理解:以上这4个词是咱们理解的关键。状态:什么是状态,咱们能够通俗的理解为数据。Vue只关心视图层,那么视图的状态如何来肯定?咱们知道是经过数据驱动,这里的状态管理能够简单理解为管理数据。集中存储:Vue
只关心视图,那么咱们须要一个仓库(Store
)来存储数据,并且是全部的数据集中存储,视图和数据就能够分析。管理:除了存储,还能够管理数据,也就是计算、处理数据。全部组件状态:所用的组件共用一个仓库(Store
),也就是一个项目只有一个数据源(区分模块modules
)。ide
总结:Vuex就是在一个项目中,提供惟一的管理数据源的仓库。工具
2.有什么用?使用场景?ui
场景一:处理多组件依赖于同一个数据,例若有柱状图和条形图两个组件都是展现的同一数据;spa
场景二: 一个组件的行为——改变数据——影响另外一个组件的视图,其实也就是公用依赖的数据;code
Vuex
将组件公用数据抽离,在一个公共仓库管理,使得各个组件容易获取(getter
)数据,也容易设置数据(setter
)。blog
3.源码初览开发
这是Vuex
的源码文件,总共包含五大部分,Plugins
两个注入文件,核心文件index
,帮组文档helper
,工具文件util.js
文档
咱们先看看Index.js
文件export
的框架,后面具体分析。
export default { Store, install, mapState, mapMutations, mapGetters, mapActions }
后面文章分析
Store
仓库。