当前位置: 移动技术网 > IT编程>脚本编程>vue.js > Vuex mutitons和actions初使用详解

Vuex mutitons和actions初使用详解

2019年03月16日  | 移动技术网IT编程  | 我要评论

南征北战短线王,杀人蛇,网站设计风格

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);
  }
}

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

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网