Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的全部组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex 也集成到 Vue 的官方调试工具 devtools extension,提供了诸如零配置的 time-travel 调试、状态快照导入导出等高级调试功能。javascript
以上是vuex的官方文档对vuex的介绍,官方文档对vuex的用法进行了详细的说明。这里就再也不细讲vuex的各个用法,写这篇博客的目的只是帮助部分同窗更快地理解并上手vuex。vue
不知道如今读这篇博客的同窗是否有看过Vue2.0子父组件之间通讯,子父组件之间的基本通讯方式。咱们通讯的目的每每就是在组件之间传递数据或组件的状态(这里将数据和状态统称为状态),进而更改状态。但能够看到若是咱们经过最基本的方式来进行通讯,一旦须要管理的状态多了,代码就会变得十分混乱。对全部状态的管理便会显得力不从心,尤为是多人合做的时候。java
此时vuex出现了,他就是帮助咱们把公用的状态全抽出来放在vuex的容器中,而后根据必定的规则来进行管理git
vuex由如下几部分组成:angularjs
- state里面就是存放项目中须要多组件共享的状态
- mutations就是存放更改state里状态的方法
- getters就是从state中派生出状态,好比将state中的某个状态进行过滤而后获取新的状态。
- actions就是mutation的增强版,它能够经过commit mutations中的方法来改变状态,最重要的是它能够进行异步操做。
- modules顾名思义,就是当用这个容器来装这些状态仍是显得混乱的时候,咱们就能够把容器分红几块,把状态和管理规则分类来装。这和咱们建立js模块是一个目的,让代码结构更清晰。
1 // 实例化vuex状态库 2 var vuexStore = new Vuex.Store({ 3 state:{ 4 message:'Hello World', 5 bookList:[ 6 { 7 name:'javascript权威指南', 8 price:100, 9 en:'jq' 10 }, 11 { 12 name:'angularjs权威指南', 13 price:80, 14 en:'aq' 15 }, 16 { 17 name:'HTTP权威指南', 18 price:50, 19 en:'hq' 20 } 21 ] 22 }, 23 mutations:{ 24 //同步 25 showMessage:function(state,data){ 26 state.message = 'Store mutations changed this words。'+data; 27 } 28 addBook:function(state,data){ 29 state.bookList.push(data) 30 } 31 }, 32 getters:{ 33 filterPrice:function(state){ 34 var narr = []; 35 for(var i = 0;i<state.bookList.length;i++){ 36 state.bookList[i].price<85 ? narr.push(state.bookList[i]) : null; 37 } 38 return narr; 39 } 40 }, 41 actions:{ 42 //异步操做 43 addBook:function(context){ 44 setTimeout(function(){ 45 context.commit('addBook',{name:'HTML5权威指南',price:75}); 46 },2000); 47 } 48 }, 49 modules:{ 50 a:storeA,b:storeB 51 } 52 }); 53 54 // vue 实例 55 var vm = new Vue({ 56 el:'app', 57 store:VuexStore, 58 methods:{ 59 showMessage:function(){ 60 this.$store.commit('showMessage','荷载数据') 61 }, 62 filterList:function(){ 63 return this.store.getters.filterPrice(); 64 }, 65 addBooks:function(){ 66 this.$store.dispatch('addBook') 67 }, 68 } 69 });
【state】vuex核心概念有五个,试想当咱们把全部的状态从各个组件抽出来,放入了state中:message和bookList;github
【mutations】某个时候,某个组件中,咱们须要把state中的message改变数据,咱们要经过调用commit方法提交到mutations对应的事件:commit('showMessage'),这样就会调用mutations里showMessage方法;调用方法是如上面代码中57行的方式;vuex
【getters】某个时间,某个组件咱们须要得到bookList中价格小于85的全部数据,vuex中容许咱们经过getters来获取:使用方法如上代码中60行网络
【actions】这个是mutations的强化部分,只是这个里面的函数能够异步操做,好比网络请求等等;这里面的方法若是要更改状态,最好要经过commit()函数提交到mutations里去处理。官方是这么说的。在实例里调用通常是经过dispatch('funName')来调用的;例如实例中:66行代码app
【关于moduls】modules其实就是多个状态管理库,放在一个对象里,好比咱们有2个状态库:storeA,storeB。咱们在modules里就和上面代码中50行的写法是同样的。异步
在取值的时候就直接在实例里调用:this.$store.state.a便可返回storeA这个store里的状态。
这里有一个点要注意一下:全部子模块里的getters对象里的方法会被合并到$store里,若是不一样子模块里有重名的方法,那么会报错;
可是全部子模块里actions和mutations中的方法不会被合并,重名也不会报错。可是当你dispatch或者commit一个同名的事件的时候,会依次执行每个子模块中的事件。
因此在不一样子模块的actions和mutations中不要写重复的函数名称;
使用Vuex
下面咱们来说一下怎么引入一个Vuex协助咱们管理状态:
首先固然要引入Vuex.js;
而后,咱们新建一个vuex实例
1 var store = new VuexStore({ 2 state:{ 3 } , 4 mountations:{ 5 }, 6 })
建立好store后咱们须要把这个store注入到vue的实例和组件中,
1 var vm = new Vue({ 2 el:'#app', 3 store:store 4 })
而后咱们就能像上面介绍的方法使用了。
最后多说一嘴,官方建议的目录结构是吧mutations,actions,getters等一系列,都分开放在不一样的目录,便于多人开发与维护。
vue到此已经研究了不少。行百里者半九十,还须要深刻研究。我的对vue2.0的总结demo已上传至gitHub。地址:https://github.com/HUA1/vue2-summary.git
本文到此结束,所涉及的vue版本是2.0.x;vuex版本是:2.2.1。
欢迎你们批评指正。