在Vuex中,Mutation是唯一允许修改状态的地方。为了遵循这个原则,我们应该避免在Mutation处理程序之外直接修改Vuex存储。
以下是解决此问题的一种常见方法:
示例代码:
// 在Vue组件中派发一个Action
this.$store.dispatch('updateName', newName);
// 在Vuex Store中定义Action和Mutation
actions: {
updateName({ commit }, newName) {
// 这里可以进行一些异步操作,如发送请求等
// 最后调用Mutation来修改状态
commit('SET_NAME', newName);
}
},
mutations: {
SET_NAME(state, newName) {
state.name = newName;
}
}
通过这种方式,我们可以避免直接在Mutation处理程序之外修改Vuex存储,确保了所有状态的修改都通过Mutation进行。
注意:如果只是想获取Vuex存储的值而不修改它,可以直接通过getter来获取。