在 vue + typescript 中使用 mapState

using mapState in vue + typescript

在远离 vue 多年后,我正在用 vue+vuex+typescript 编写一个应用程序。我明白了这些概念,但发生了很多变化!

我 运行 在尝试使用 vuex mapState 辅助函数时遇到了一个奇怪的问题。我有一个名为 animationCanvas:

的商店模块
import { Module } from 'vuex'
import { RootState } from '../types'
import { AnimationCanvasState } from './types'

const state: AnimationCanvasState = {
  frames: [],
}

export const animationCanvas: Module<AnimationCanvasState, RootState> = {
  state,
}

我将它拉入我的根存储模块并注册它:

import { createStore, StoreOptions } from 'vuex'
import { RootState } from './types'
import { animationCanvas } from '@/store/modules/AnimationCanvas'

const store: StoreOptions<RootState> = {
  modules: {
    animationCanvas,
  },
}

当我在直接从 $store 属性 拉取的组件中使用商店时,它工作正常:

import { Vue, Options } from 'vue-class-component';

@Options({
    name: 'Animation Canvas',
    computed: {
        frames() {
            return this.$store.state.animationCanvas.frames;
        },
    },
})
export default class AnimationCanvas extends Vue {
...

但是当我尝试通过 mapState 辅助函数添加它时,我什么也没得到:

import { Vue, Options } from 'vue-class-component';
import { mapState } from 'vuex';

@Options({
    name: 'Animation Canvas',
    computed: {
        ...mapState('animationCanvas', ['frames']),
    },
})
export default class AnimationCanvas extends Vue {

而且我知道该模块在那里并且命名正确,部分原因是它在 $store 样式路径中工作,还因为我可以在开发工具中看到它:

我一直在查看文档,但我不太明白。有什么想法吗?

在您的代码中,我没有看到您为 Vuex 模块命名空间。我不知道打字稿的语法,但在普通的 JS 中你会做

const store = {
  modules: {
    animationCanvas: {
       namespaced: true,
       state: ...
    }
  }
}

您可以通过在您的组件中执行 console.log(this.$store) 并查看对象的结构来检查这一点。在你的吸气剂中你应该有这样的东西:

getters: {
   'animationCanvas/frames': ...
}