这篇文章有更新,请参阅第一个答案
所以,首先,我确实搜索了类似的问题(并找到了一些线程),但没有解决我的问题。我第一次尝试使用类星体框架,也许我在名称空间或某处丢失了。
首先,一些信息:
+使用ESLint编译时没有任何错误
+我在运行时的javascript控制台中没有任何错误
我的问题是:
+我的行为和变异会在商店中保存一些东西,但不能保存在应有的位置(见帖子末尾的截图)
+我的getter似乎不起作用,并在vue dev工具中显示为“undefined”
我的商店组织如下:
+store [folder]
+ index.js
+ app-utils [folder]
--+ index.js
--+ getters.js
--+ actions.js
--+ mutations.js
--+ state.js
root index.js的代码:
从'vue'导入Vue
从'vuex'导入Vuex
import appUtils from './app-utils'
Vue.use(Vuex)
const store = new Vuex.Store({
modules: {
appUtils
}
})
export default store
然后,在'app-utils'文件夹中: index.js的代码:
import state from './state'
import * as getters from './getters'
import * as mutations from './mutations'
import * as actions from './actions'
export default {
namespaced: true,
state,
getters,
mutations,
actions
}
state.js的代码:
export default {
state: {
currentPageTitle: 'Hello'
}
}
getters.js代码:
export const getPageTitle = (state) => {
console.log('GET TITLE: ' + state.currentPageTitle)
return state.currentPageTitle
}
antibodies.js的代码:
export const setPageTitle = (state, newPageTitle) => {
console.log('MUTATION SET TITLE: ' + newPageTitle)
state.currentPageTitle = newPageTitle
}
export const deletePageTitle = (state) => {
console.log('MUTATION DELETE TITLE')
state.currentPageTitle = ''
}
代码for actions.js:
export const setPageTitle = (context, newPageTitle) => {
console.log('ACTION SET TITLE: ' + newPageTitle)
context.commit('setPageTitle', newPageTitle)
}
export const deletePageTitle = (context) => {
console.log('ACTION DELETE TITLE')
context.commit('deletePageTitle')
}
我尝试访问它的代码(在getPageTitle计算字段中):
<template>
<q-page>
<q-resize-observable @resize="onResize" /> TITLE : {{getPageTitle}}
<div class="row">
</div>
</q-page>
</template>
import { mapGetters, mapActions } from 'vuex'
export default {
data: () => ({
pageSize: {
height: 0,
width: 0
}
}),
mounted () {
this.setPageTitle('Template manager')
},
destroyed () {
this.deletePageTitle()
},
computed: {
...mapGetters('appUtils', [
'getPageTitle'
])
},
methods: {
...mapActions('appUtils', [
'setPageTitle',
'deletePageTitle'
]),
onResize (size) {
this.pageSize = size
}
}
}
</script>
<style>
</style>
最后,来自vue插件的截图,你可以看到在触发mount()挂钩时设置了值,但是没有在'state'中设置,并且getter未定义。
答案 0 :(得分:3)
您的州对象如下所示:
export default {
state: {
currentPageTitle: 'Hello'
}
}
整个事情都被传递给你的getter状态参数。整个导出的对象是你的状态,而不是&#34;状态&#34;其中的财产。所以你有两个选择:
选项一:更新你的getter以访问嵌套的&#34;状态&#34;你所在州的财产:
export const getPageTitle = (state) => {
console.log('GET TITLE: ' + state.state.currentPageTitle)
return state.state.currentPageTitle
}
选项二(可能你真正想要做的):将你的状态对象改为没有&#34;状态&#34;属性。
export default {
currentPageTitle: 'Hello'
}
答案 1 :(得分:0)
更新:已解决,请参阅选定的答案
所以我解决了我的问题。似乎发送到我的变异的第一个参数不是状态,而是存储本身。所以:
这不起作用
export const setPageTitle = (state, newPageTitle) => {
console.log('MUTATION SET TITLE: ' + newPageTitle)
state.currentPageTitle = newPageTitle
}
此作品
export const setPageTitle = (store, newPageTitle) => {
console.log('MUTATION SET TITLE: ' + store.newPageTitle)
store.state.currentPageTitle = newPageTitle
}
这是正常行为吗?文档似乎说第一个论点应该是国家本身。