首页 > 编程 > JavaScript > 正文

Vuex mutitons和actions初使用详解

2019-11-19 12:02:48
字体:
来源:转载
供稿:网友

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 @click="commitChange">更改count</button><button @click="dispatchChange">更改count</button>...methods:{  commitChange(){    this.$store.commit('change',1);  },  dispatchChange(){    this.$sotre.dispatch('change',10);  }}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表