zoukankan      html  css  js  c++  java
  • vue组件化开发-vuex状态管理库

    Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex 也集成到 Vue 的官方调试工具 devtools extension,提供了诸如零配置的 time-travel 调试、状态快照导入导出等高级调试功能。

    以上是vuex的官方文档对vuex的介绍,官方文档对vuex的用法进行了详细的说明。这里就不再细讲vuex的各个用法,写这篇博客的目的只是帮助部分同学更快地理解并上手vuex。

    为什么要用vuex

    不知道现在读这篇博客的同学是否有看过Vue2.0子父组件之间通信,子父组件之间的基本通信方式。我们通信的目的往往就是在组件之间传递数据或组件的状态(这里将数据和状态统称为状态),进而更改状态。但可以看到如果我们通过最基本的方式来进行通信,一旦需要管理的状态多了,代码就会变得十分混乱。对所有状态的管理便会显得力不从心,尤其是多人合作的时候。

    此时vuex出现了,他就是帮助我们把公用的状态全抽出来放在vuex的容器中,然后根据一定的规则来进行管理

    Vuex的核心

    vuex由以下几部分组成:

    • state
    • mutations
    • getters
    • actions
    • modules
    • state里面就是存放项目中需要多组件共享的状态
    • mutations就是存放更改state里状态的方法
    • getters就是从state中派生出状态,比如将state中的某个状态进行过滤然后获取新的状态。
    • actions就是mutation的加强版,它可以通过commit mutations中的方法来改变状态,最重要的是它可以进行异步操作
    • modules顾名思义,就是当用这个容器来装这些状态还是显得混乱的时候,我们就可以把容器分成几块,把状态和管理规则分类来装。这和我们创建js模块是一个目的,让代码结构更清晰。

    实例来理解Vuex

     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;

    【mutations】某个时候,某个组件中,我们需要把state中的message改变数据,我们要通过调用commit方法提交到mutations对应的事件:commit('showMessage'),这样就会调用mutations里showMessage方法;调用方法是如上面代码中57行的方式;

    【getters】某个时间,某个组件我们需要获得bookList中价格小于85的所有数据,vuex中允许我们通过getters来获取:使用方法如上代码中60行

    actions】这个是mutations的强化部分,只是这个里面的函数可以异步操作,比如网络请求等等;这里面的方法如果要更改状态,最好要通过commit()函数提交到mutations里去处理。官方是这么说的。在实例里调用一般是通过dispatch('funName')来调用的;例如实例中:66行代码

    【关于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。

    欢迎大家批评指正。

  • 相关阅读:
    3Sum Closest
    二叉树的下一个结点
    数组中重复的数字
    不用加减乘除做加法
    和为S的连续正数序列
    数组中只出现一次的数字
    求二叉树的是否为平衡二叉树
    由一道很简单的求两条链表的第一个公共节点的问题引发的思考
    第14章 网络编程
    第13章 文档与串行化
  • 原文地址:https://www.cnblogs.com/wwlhome/p/6522853.html
Copyright © 2011-2022 走看看