如何正确使用Vuex的mutations和actions进行状态管理?
- 内容介绍
- 文章标签
- 相关推荐
本文共计865个文字,预计阅读时间需要4分钟。
%E2%80%9CMutations%20mutations%20%E5%BF%85%E9%A1%BB%E6%98%AF%E5%90%8C%E6%AD%A5%E5%87%BD%E6%95%B0%2C%E4%B8%BA%E4%BB%80%E4%B9%88%20%E4%BD%BF%E7%94%A8%E4%BE%8B%E5%AD%90%3A%20%E5%AE%98%E6%96%B9%E6%A1%88%E4%BE%8B%20mutations%3A%20%7B%20someMutation%20(%E7%8A%B6%E6%80%81)%20%7B%20api.callAsyncMethod%20((%E7%8A%B6%E6%80%81)%20%3D%20%7B%20%E7%8A%B6%E6%80%81.count%20%2B%201%20%7D)%20%7D%7D%20%E6%88%91%E4%BB%AC%E9%83%BD%E7%9F%A5%E9%81%93%E5%9B%9E%E8%B0%83%E5%87%BD%E6%95%B0%E4%B8%AD%E8%BF%9B%E8%A1%8C%E7%9A%84%E7%8A%B6%E6%80%81%E6%94%B9%E5%8F%98%E6%98%AF%E6%97%A0%E6%B3%95%E8%BF%BD%E8%B8%AA%E7%9A%84%E2%80%9D%EF%BC%9B
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); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。
本文共计865个文字,预计阅读时间需要4分钟。
%E2%80%9CMutations%20mutations%20%E5%BF%85%E9%A1%BB%E6%98%AF%E5%90%8C%E6%AD%A5%E5%87%BD%E6%95%B0%2C%E4%B8%BA%E4%BB%80%E4%B9%88%20%E4%BD%BF%E7%94%A8%E4%BE%8B%E5%AD%90%3A%20%E5%AE%98%E6%96%B9%E6%A1%88%E4%BE%8B%20mutations%3A%20%7B%20someMutation%20(%E7%8A%B6%E6%80%81)%20%7B%20api.callAsyncMethod%20((%E7%8A%B6%E6%80%81)%20%3D%20%7B%20%E7%8A%B6%E6%80%81.count%20%2B%201%20%7D)%20%7D%7D%20%E6%88%91%E4%BB%AC%E9%83%BD%E7%9F%A5%E9%81%93%E5%9B%9E%E8%B0%83%E5%87%BD%E6%95%B0%E4%B8%AD%E8%BF%9B%E8%A1%8C%E7%9A%84%E7%8A%B6%E6%80%81%E6%94%B9%E5%8F%98%E6%98%AF%E6%97%A0%E6%B3%95%E8%BF%BD%E8%B8%AA%E7%9A%84%E2%80%9D%EF%BC%9B
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); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持自由互联。

