vue vuex搭建vuex环境及vuex求和的方法-亚博电竞手机版

vue vuex搭建vuex环境及vuex求和的方法

今天小编给大家分享一下vuevuex搭建vuex环境及vuex求和的方法的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

    vuex介绍

    概念

    在 vue 中实现集中式状态(数据)管理的一个 vue 插件,对 vue 应用中多个组件的共享状态进行集中式的管理(读写),也是一种组件间通信的方式,且适用于任意组件间通信

    何时使用

    多个组件需要共享数据时

    求和案例–纯vue版

    新建 count.vue 组件,并在 app.vue 中注册引用

    我们主要关注 count.vue

    select,button{margin-right:5px;}

    搭建vuex环境

    注意:

    vue2 中要使用 vuex 的 3 版本
    vue3 中要使用 vuex 的 4 版本

    因为我们使用的是 vue2 所以我们需要安装 vuex 的 3 版本

    • 1、执行 npm i vuex@3 来安装 vuex 3 版本

    • 2、src 下创建 store 文件夹,在其中创建一个 index.js

    index.js

    //该文件用于创建vuex中最为核心的store//引入vueximportvuexfrom'vuex'//引入vueimportvuefrom"vue";//应用vuex插件vue.use(vuex)//准备actions;用于相应组件中的动作constactions={}//准备mutations;用于操作数据(state)constmutations={}//准备state;用于存储数据conststate={}//创建并暴露storeexportdefaultnewvuex.store({actions:actions,mutations,//key和value重名了,简写state,//key和value重名了,简写});

    3、main.js 中引入刚才写好的 store

    ......//引入store//importstorefrom'./store/index'importstorefrom'./store'......//创建vmnewvue({el:"#app",//store:storestore,//触发简写形式......})

    运行项目,我们可以打印 vm 和 vc,可以看到 $store

    求和案例–vuex版

    我们将求和的案例改为 vuex 版本

    1、首先把数据交给 state

    所以我们把 count 组件中的数据 sum 变量剪切走放到 index.js 中的 state 中,同时 count 组件中的方法,例如加法 increment 中使用 this.$store.dispatch("方法名",变量) 来替代原来的方法。这样就走完了流程图中以下部分

    count.vue

    同时 index.js 中的 action 中添加对应的方法名,从图上的流程图来看,actions 中的东西会交到 mutations 中处理,所以需要手动调用 commit方法

    mutation 中也需要增加同样的方法名,这里可以都改成大写,做个区分。方法中第一个参数就是 state,方法中处理真实逻辑即可

    index.js

    //该文件用于创建vuex中最为核心的store//引入vueximportvuexfrom'vuex'//引入vueimportvuefrom"vue";//应用vuex插件vue.use(vuex)//准备actions;用于相应组件中的动作constactions={/*jia:function(){}*///简写为:jia(context,value){console.log("actions中的jia被调用了",context,value);context.commit("jia",value)}}//准备mutations;用于操作数据(state)constmutations={jia(state,value){console.log("mutations中的jia被调用了",state,value);state.sum =value;}}//准备state;用于存储数据conststate={sum:0,//当前和}//创建并暴露storeexportdefaultnewvuex.store({actions:actions,mutations,//key和value重名了,简写state,//key和value重名了,简写});

    log 输出:

    运行程序:

    我们根据以上思路完善其他方法

    count.vue

    select,button{margin-right:5px;}

    index.js

    //该文件用于创建vuex中最为核心的store//引入vueximportvuexfrom'vuex'//引入vueimportvuefrom"vue";//应用vuex插件vue.use(vuex)//准备actions;用于相应组件中的动作constactions={/*jia:function(){}*///简写为:jia(context,value){console.log("actions中的jia被调用了");context.commit("jia",value)},jiaodd(context,value){console.log("actions中的jianodd被调用了");if(context.state.sum%2){context.commit("jia",value)}},jiawait(context,value){console.log("actions中的jianwait被调用了");settimeout(()=>{context.commit("jia",value)},500)}}//准备mutations;用于操作数据(state)constmutations={jia(state,value){console.log("mutations中的jia被调用了",state,value);state.sum =value;},jian(state,value){console.log("mutations中的jian被调用了",state,value);state.sum-=value;}}//准备state;用于存储数据conststate={sum:0,//当前和}//创建并暴露storeexportdefaultnewvuex.store({actions:actions,mutations,//key和value重名了,简写state,//key和value重名了,简写});

    到此为止,功能就实现了,你发现了吗,这里做了些优化,由于 index.js 中的 jia、jian方法里边什么都没做,直接就 commit 给了 mutation,而 vc 是可以直接对话 mutations 的,如下图:

    所以我们把 index.js 中 actions 中的 jian方法去掉,在 count 中直接调用 mutation 中的方法,也就是我们把 jian方法去掉,在 count 的 decrement 方法中直接调用 commit 了

    decrement(){this.$store.commit("jian",this.n);},

    若没有网络请求或其他业务逻辑,组件中也可以越过 actions,即不写 dispatch,直接编写 commit

    一些疑惑和问题

    index.js 中的上下文有什么作用?我们可以打印下 context:

    可以看到其中有dispatch、commit、state这些熟悉的身影。我们用 jiaodd 举例,当方法逻辑处理复杂时,可以继续 dispatch 其他方法来分担。而有了 state 我们可以拿到其中的 sum 值:

    jiaodd(context,value){console.log("actions中的jianodd被调用了",context);if(context.state.sum%2){context.commit("jia",value)}context.dispatch("demo",value)},demo(){//处理一些事情},

    以上就是“vuevuex搭建vuex环境及vuex求和的方法”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注恰卡编程网行业资讯频道。

    展开全文
    内容来源于互联网和用户投稿,文章中一旦含有亚博电竞手机版的联系方式务必识别真假,本站仅做信息展示不承担任何相关责任,如有侵权或涉及法律问题请联系亚博电竞手机版删除

    最新文章

    网站地图