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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...