首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从另一个模块访问vuex模块状态

从另一个模块访问vuex模块状态
EN

Stack Overflow用户
提问于 2018-12-13 04:20:09
回答 1查看 10.4K关注 0票数 4

我正在学习vuex,并取得了一些进展,但我被困在了一些事情上。我有一个包含多个模块的存储区的vue组件。我有带设备的地点。用户选择一个位置,而我将其存储在我的vuex状态中的location模块中。

我试图从设备模块访问该位置,以便只加载所选位置的设备。

文件上说,这应该是可行的:

代码语言:javascript
复制
actions: {
incrementIfOddOnRootSum ({ state, commit, rootState }) {
  if ((state.count + rootState.count) % 2 === 1) {
    commit('increment')
  }
}

当我在我的模块中尝试这个时:

代码语言:javascript
复制
GET_EQUIPMENTS : async (context,payload, rootState) => {
  alert(JSON.stringify(rootState.location, null, 4));
}

我得到错误rootState是没有定义的。

如果我提醒上下文,我可以看到rootGetters

代码语言:javascript
复制
{
  "getters": {},
  "state": {
    "equipments": [],
    "equipment": null
  },
  "rootGetters": {
    "locations/LOCATIONS":[
    {
       "id": 1,
       "name": "West Pico",
    }
  }
}

但是我不知道如何访问位置/位置,我可以通过访问rootGetters访问context.rootGetters。

有什么建议吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-12-13 05:21:08

基于https://vuex.vuejs.org/guide/modules.html

您应该将state, commit, rootState包装在{..}中以执行操作:

代码语言:javascript
复制
actions: {
    incrementIfOddOnRootSum({ state, commit, rootState }, yourParam) {
      if ((state.count + rootState.count + yourParam) % 2 === 1) {
        commit('increment');
      }
    }
  }
票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53754966

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档