Задать вопрос
alaskafx
@alaskafx
Не .do Frontend

Почему Vuex работает «рандомно» и как правильно достать из него state?

Есть хранилище:

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

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
    userData: ''
  },
  mutations: {
    setData: function(state, data) {
      state.userData = data
    }
  },
  actions: {
  },
  modules: {
  }
})


Есть компонент, который достаёт этот самый userData из хранилища:

export default {
        name: 'Profile',
        data() {
            return {
                userData: this.$store.state.userData
            }
        },
    }


Проблема в том, что это работает совершенно рандомно:
Он может показывать userData, а может не показывать.
В основном, в компоненте отображается либо пустая строка, либо undefined.


Не понимаю в чём дело - как решить эту проблему?
  • Вопрос задан
  • 83 просмотра
Подписаться 1 Простой 2 комментария
Пригласить эксперта
Ответы на вопрос 2
@PavelPlot99
Нужно создать getters так:
getters: {
        userData: state => {
            return state.UserData;
        }

А потом получать объект из хранилища вот так:

this.$store.getter.userData
Ответ написан
nuykon
@nuykon
Full Stack Developer
Асинхронность!!!
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы