尝试从 Vuex 模块调度操作不起作用。 [vuex] 未知动作类型

Posted

技术标签:

【中文标题】尝试从 Vuex 模块调度操作不起作用。 [vuex] 未知动作类型【英文标题】:Trying to dispatch action from Vuex module doesn't work. [vuex] unknown action type 【发布时间】:2021-11-28 17:49:58 【问题描述】:

我正在尝试注册一个 Vuex 模块但没有成功。这是我的代码:

商店/index.js:

import Vuex from 'vuex';
import resourcesModule from './resources';

import axios from '@/helpers/axiosInterceptor';

Vue.use(Vuex);


export default new Vuex.Store(
  modules: 
    resources: resourcesModule
  ,
  state: ...)

商店/资源/index.js


export default 
    state: 
        resources: []
    ,
    actions: 
        fetchResources(store) 
            const request = axios.get('/api/musical_resources');
            request.then((res) => 
                store.commit('setResources', res.data);;
            ); 
            return request;
        
    ,
    mutations: 
        setResources(state, payload) 
            state.resources = payload;
        
    ,
    getters: 
        resources(resources) 
            return resources;
        
    
;

我正在尝试从另一个组件调度“fetchResources”操作,这给了我“[vuex] 未知操作类型:fetchResources”

当我检查 store 对象时,在 _modules 属性中只有“root”属性,所以我怀疑注册模块时可能遗漏了一些东西。

当我 console.log(resourcesModules);在stores/index.js 文件中一切看起来都很好。

那么,我的问题是什么?非常感谢

编辑:

也在 stores/index.js 中尝试过这个:

import Vue from 'vue';
import Vuex from 'vuex';

import axios from '@/helpers/axiosInterceptor';

Vue.use(Vuex);


export default new Vuex.Store(
  modules: 
    resources: 
      state() 
        return 
          resources: []
        
      ,
      actions: 
        fetchResources(store) 
          const request = axios.get('/api/musical_resources');
          request.then((res) => 
            store.commit('setResources', res.data);;
          );
          return request;
        
      ,
      mutations: 
        setResources(state, payload) 
          state.resources = payload;
        
      ,
      getters: 
        resources( resources ) 
          return resources;
        
      
    
  ,
  state: ...)

没有成功

【问题讨论】:

【参考方案1】:

试试这个方法:

export default new Vuex.Store(
  modules: 
    resourcesModule
  ,
  state: ...)

发送fetchResources

export default new Vuex.Store(
  modules: 
    resources: resourcesModule
  ,
  state: ...)

发送resources.fetchResources

【讨论】:

是的!非常感谢!那么,这种行为与“命名空间:真”有何不同。这有点令人困惑!再次感谢您! 对不起!我实际上是在没有从根存储中删除“fetchResources”的情况下对其进行测试。还是不行:( 你确定?它应该可以工作,它适用于我的很多项目 是的,我不知道为什么不起作用。看看我的回购对你有帮助吗?就是这个github.com/damianciancio/gestion-orquestas 嘿伙计,我看了你的仓库,你有import musicalResources from './resources';,但你的modules是空的,把你导入的模块放在modules: musicalResources ,里面

以上是关于尝试从 Vuex 模块调度操作不起作用。 [vuex] 未知动作类型的主要内容,如果未能解决你的问题,请参考以下文章

尝试从 vuejs 组件调度操作时,vuex 未知操作类型

无法在组件中调度 Vuex 模块的操作

为啥 router.push 不起作用? [Vue 3] [Vuex 4]

使用 Vuex 4 在 Vue 3 中设置状态数据不起作用

Vue 3 - 如何使用 vuex 模块?

存储在 Vuex 4 中 Vuejs 3 不起作用并显示空白结果