如何解决Vuex 使用其他模块中的功能改变模块中的状态
我在 Vuex 中有 2 个模块:
- 身份验证(auth.js)
- 用户(user.js)
const actions = {
[UPDATE_USER_ACCOUNT](context,payload) {
return new Promise(resolve => {
ESApiService.put("/api/user",payload)
.then(({ data }) => {
context.commit('[SET_AUTH]',data.data.user,{ root: true })
//context.commit(SET_USER_ACCOUNT,payload);
resolve(data);
})
.catch(({ response }) => {
context.commit(SET_ERROR,response);
});
});
},}
当前的问题是我收到以下错误:[vuex] unkNown mutation type: [SET_AUTH]
我也尝试过:context.commit('SET_AUTH',{ root: true })
并收到此错误:[vuex] unkNown mutation type: SET_AUTH
SET_AUTH 注册在:auth.js 如下:
[SET_AUTH](state,user) {
state.isAuthenticated = true;
state.user = user;
state.errors = {};
},
如何让它工作?
解决方法
如果你不使用命名空间,试试这个:
commit('SET_AUTH',data.data.user,{ root: true })
如果您使用命名空间
commit('namespace/SET_AUTH',{ root: true })
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。