vue.js - Vuex 模块 - 无法正确设置 ..mapGetters

标签 vue.js vuex vuex-modules

我目前定义的商店结构如下

store
  modules
    User.js
 index.js

商店/模块/User.js

import * as types from '@/store/mutation_types'
import firebase from 'firebase'

const state = {
  ...
  user: JSON.parse(localStorage.getItem('user')) || null
}

const actions = {
  setUser ({commit}, newUser) {
    console.log('STORE ACTION setUser: ', newUser)
    commit(types.SET_USER, newUser)
  },
  signUserIn ({commit}, payload) {
    ...
  },
  signUserUp ({commit}, payload) {
    ...
  },
  logout: context => {
   ...
  }
}

const mutations = {
 ...
}

const getters = {
  ...
  user: state => state.user
}

export const User = {
  namespaced: true,
  state,
  actions,
  mutations,
  getters
}

商店/index.js

/**
 * Import Dependency
 */
import Vue from 'vue'
import Vuex from 'vuex'
import { firebaseMutations } from 'vuexfire'
import * as types from '@/store/mutation_types'
import { User } from '@/store/modules/User.js'
import { Account } from '@/store/modules/Account.js'

Vue.use(Vuex)

const store = new Vuex.Store({
  strict: process.env.NODE_ENV !== 'production',
  state: {
    language: localStorage.getItem('language') || '',
    ...
  },
  actions: {
    switchLanguage ({ commit }, context) {
      commit(types.SET_LANGUAGE, context)
    },
    ...
  },
  getters: {
    language: state => state.language,
    sideNav: state => state.sideNav,
    showAssociation: state => state.showAssociation,
    ...
  },
  mutations: {
    ...
    },
    ...firebaseMutations
  },
  modules: {
    User,
    Account
  }
})

export default store

在组件中,我需要使用来自用户模块和index.js的..mapGetters

...mapGetters('用户', ['用户'], ['sideNav', 'showAssociation']),

但这不对...我收到错误:

 Property or method "showAssociation" is not defined

我应该如何编写我的 ...mapGetters ? 或者我的用户模块中有什么问题吗?

感谢反馈

最佳答案

如果您需要从不同模块获取 getter,只需分别映射它们即可:

computed: {
  ...mapGetters('User', ['user']),
  ...mapGetters(['showAssociation', 'sideNav'])
}

关于vue.js - Vuex 模块 - 无法正确设置 ..mapGetters,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51341724/

相关文章:

javascript - 如何重置/删除 vuex 存储数据?

javascript - 为什么没有定义 $store?

javascript - 多个Highcharts-Vue股票图表中同步x轴缩放

vue.js - 有没有办法在两个命名空间的 vuex 模块之间分派(dispatch)操作?

vue.js - vue中输入失去焦点时如何执行函数

vue.js - 如何更改 v-carousel 滚动/幻灯片过渡速度?

javascript - Nuxt auth getToken witnin async 未定义

javascript - Vuex 2.0 Dispatch 与 Commit

performance - Nuxt 在语言环境上构建非常慢