Vuex mutitons和actions初使用详解
Mutations
mutations必须是同步函数,为什么?
举个例子: 官方案例
mutations:{
someMutation(state){
api.callAsyncMethod(()=>{
state.count++
})
}
}
我们都知道任何回调函数中进行的状态改变都是无法追踪的, devtools会对mutations的每一条提交做记录,记录上一次提交之前和提交之后的状态,在上面的例子中无法实现捕捉状态,因为在执行mutations时,内部回调函数还没有执行,
所以此时无法捕捉状态.
再简单来讲,就像大家都吃过核桃,核桃刚产下来的时候是带一层绿色的皮的,我们需要将绿色烧掉,弄掉了,才是我们在市场上见到的只有外面硬壳的核桃,如果我们只剥去绿皮,是不能直接吃的,因为还有一层壳胡着呢.
Actions
vuex肯定不甘示弱,为了解决mutations只有同步的问题,提出了actions(异步),专门用来解决mutations只有同步无异步的问题.
1.首先先了解一下actions
(1).MUTATIONS
conststate={
xxx:null
},
constmutations={
[setState](state,value){
state.xxx=value
}
}
此处value可以是对象,可以是值等
组件调用方式:this.$store.commit('setState',[value])
(2).ACTIONS
//第一种写法简写形式
constactions={
[addPlus]({commit}){//简写方式,待研究
commit('[setState]',value)
//此处value可以是对象,可以是固定值等
}
}
//第二种形式
constactions={
[addPlus](context){
//context官方给出的指定对象,此处context可以理解为store对象
context.commit('[setState]',value)
}
}
/*两处的commit都是提交的mutations中的字符串的事件类型名称,对应会调用mutations中的回调函数*/
actions在组件中的调用方式:
importmapActionsfrom'vuex'
methods:{
...mapActions:([
'addPlus'
]),
setAddPlus(){
this.$store.dispatch('addPlus',[value])//异步调用mutations
}
}
Vuex状态管理
Vuex依赖于Vue用来管理Vue项目状态
状态的修改依赖于commit和dispatch
importVuefrom'Vue';
importVuexfrom'Vuex';
exportdefaultnewVuex.Store({
state:{
count:100
},
mutations:{
change(state,payload){
state.count+=payload;
}
},
actions:{
change(context,palyload){
context.commit('change',palyload);//异步触发mutaiton
}
},
getters:{
getCount(){
returnstate.count;
}
}
})
{{$store.state.count}}
...
methods:{
commitChange(){
this.$store.commit('change',1);
},
dispatchChange(){
this.$sotre.dispatch('change',10);
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。