定义
: 在Vuex中,actions和mutations是两个核心概念,用于管理应用程序状态的变化。
一: Mutations
mutations是用于修改Vuex状态的唯一方法。它们是同步操作,意味着它们必须是纯函数,以确保状态的可预测性。这意味着mutations应该只用于同步操作,例如在响应用户事件时更新状态。它们不应该包含任何异步代码,如API调用。
举个例子,下面的代码演示了如何定义一个名为increment的mutation,用于将state中的count属性增加
const store = new Vuex.Store({
state: {
count: 0
},
mutations: {
increment(state) {
state.count++
}
}
})
store.commit('increment') // 调用mutation
二:Actions
actions用于执行异步操作或包含异步操作的操作序列。它们可以包含任何异步代码,例如API调用或其他异步操作,但不能直接修改状态。相反,它们通过commit触发mutations来间接修改状态。
举个例子,下面的代码演示了如何定义一个名为fetchData的action,它会异步获取数据并提交mutation来更新状态:
const store = new Vuex.Store({
state: {
data: null
},
mutations: {
setData(state, data) {
state.data = data
}
},
actions: {
async fetchData({ commit }) {
const response = await fetch('https://api.example.com/data')
const data = await response.json()
commit('setData', data)
}
}
})
store.dispatch('fetchData') // 调用action
总之,mutations和actions有不同的角色和职责。mutations用于同步状态的修改,actions用于执行异步操作并间接修改状态。