在 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': ...
}
在远离 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': ...
}