• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Vuex mutitons和actions初使用详解

vue 搞代码 4年前 (2022-01-08) 21次浏览 已收录 0个评论

这篇文章主要介绍了Vuex mutitons和actions初使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

Mutations

mutations 必须是同步函数,为什么?

举个例子:  官方案例

 mutations: { someMutation (state) { api.callAsyncMethod(() => { state.count++ }) } } 

我们都知道任何回调函数中进行的状态改变都是无法追踪的,  devtools会对mutations的每一条提交做记录,记录上一次提交之前和提交之后的状态,在上面的例子中无法实现捕捉状态,因为在执行mutations时,内部回调函数还没有执行,

所以此时无法捕捉状态.

再简单来讲,就像大家都吃过核桃,核桃刚产下来的时候是带一层绿色的皮的,我们需要将绿色烧掉,弄掉了,才是我们在市场上见到的只有外面硬壳的核桃,如果我们只剥去绿皮,是不能直接吃的,因为还有一层壳胡着呢.

Actions

vuex肯定不甘示弱,为了解决mutations只有同步的问题,提出了actions(异步),专门用来解决mutations只有同步无异步的问题.

1. 首先先了解一下actions

(1).MUTATIONS

 const state = {     xxx: null   },   const mutations = {     [setState](state, value) {       state.xxx = value     }   }

此处value可以是对象,可以是值等

组件调用方式: this.$store.commit(‘setState’, [value])

(2).ACTIONS

   // 第一种写法简写形式   const actions = {     [addPlus]({commit}) { // 简写方式,待研究       commit('[setState]', value)       //此处value可以是对象,可以是固定值等     }   }   // 第二种形式   const actions = {     [addPlus](context) {       //context 官方给出的指定对象, 此处context可以理解为store对象       context.commit('[setState]', value)     }   }   /* 两处的commit都是提交的mutations中的字符串的事件类型名称,对应会调用mutations中的回调函数 */   actions在组件中的调用方式:   import mapActions from 'vuex'   methods: {     ...mapActions: ([      'addPlus'      ]),     setAddPlus () {       this.$store.dispatch('addPlus', [value]) // 异步调用mutations     }   }

Vuex 状态管理

Vuex 依赖于 Vue 用来管理 Vue 项目状态

状态的修改依赖于 commit 和 dispatch

 import Vue from 'Vue'; import Vuex from 'Vuex'; export default new Vuex.Store({ state:{ count:100 }, mutations:{ change(state,payload){ state.count += payload; } }, actions:{ change(context,palyload){ context.commit('change',palyload);// 异步触发 mutaiton } }, getters:{ getCount(){ return state.count; } } })
 {{$store.state.count}} <button>更改count</button><button>更改count</button> ... methods:{ commitChange(){ this.$store.commit('change',1); }, dispatchChange(){ this.$sotre.dispatch('chang<p>本文来源gao!daima.com搞$代!码#网#</p>e',10); } } 

以上就是Vuex mutitons和actions初使用详解的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Vuex mutitons和actions初使用详解

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址