之前写过简单的vuex应用方法,现在写一下vuex中的 actions 和 mutations 的区别
Mutations
mutations 必须是同步函数,为什么?
举个例子: 官方案例
mutations: { someMutation (state) {
api.callAsyncMethod(() => {
state.count++ }) }}
我们都知道任何回调函数中进行的状态改变都是无法追踪的, devtools会对mutations的每一条提交做记录,记录上一次提交之前和提交之后的状态,在上面的例子中无法实现捕捉状态,因为在执行mutations时,内部回调函数还没有执行,
所以此时无法捕捉状态.
再简单来讲,就像大家都吃过核桃,核桃刚产下来的时候是带一层绿色的皮的,我们需要将绿色烧掉,弄掉了,才是我们在市场上见到的只有外面硬壳的核桃,如果我们只剥去绿皮,是不能直接吃的,因为还有一层壳胡着呢.
Actions
vuex肯定不甘示弱,为了解决mutations只有同步的问题,提出了actions(异步),专门用来解决mutations只有同步无异步的问题.
1. 首先先了解一下actions,第一篇vuex中已经讲解了vuex中mutations的用法(https://www.cnblogs.com/0915ty/p/9330439.html),在这里再介绍一下
(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
}
}
简单说到这里,先会用在研究原理
再接再厉,继续努力!!!!!
原文出处:https://www.cnblogs.com/0915ty/p/9626240.html
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦