проблемы с визуализацией данных Vuex

проблемы с визуализацией данных Vuex

14.03.2020 07:18:56 Просмотров 1 Источник

Я изучаю реактивность vuex, используя nuxt и модульный режим хранения. Проблема заключается в том, что несмотря на то, что все данные в хранилище успешно изменены действиями => мутации, они не появляются на странице, а показывают только пустой новый элемент массива хранилища. вот мои файлы:

магазин>контакты> > индекс.JS:

let initialData = [
  {
    id: 1,
    name: 'Michael',
    email: 'michael.s@mail.com',
    message: 'message from Michael'
  },
  {
    id: 2,
    name: 'Mark',
    email: 'mark.sh@email.com',
    message: 'message from Mark'
  },
  {
    id: 3,
    name: 'Valery',
    email: 'valery.sh@mail.com',
    message: 'message from Valery'
  }
]
const state = () =>{
  return {
    contacts: []
  }
}
const getters = {
  allContacts (state) {
    return state.contacts
  }
}

const actions = {
  async initializeData({ commit }) {
    commit('setData', initialData)
  },
  addNewContact({ commit, state }, newContact) {
    commit('addContact', newContact)
  }
}

const mutations = {
  setData: (state, contacts) => (state.contacts = contacts),
  addContact: (state, newContact) => state.contacts.push(newContact)
}


export default { state, getters, mutations, actions}

сама компонента:

<template>
  <div class="contact-form">
    <div class="links">
      <nuxt-link to="/">home</nuxt-link>
      <nuxt-link to="/contact-form">contact form</nuxt-link>
    </div>
    <h1>leave your contacts and message here:</h1>
    <div class="input-wrapper">
      <form class="feedback-form" action="">
        <div class="name">
          <label for="recipient-name" class="col-form-label">Ваше имя:</label>
          <input type="text" id="recipient-name" v-model="obj.userName" name="name" class="form-control" placeholder="Представьтесь, пожалуйста">
        </div>
        <div class="form-group">
          <label for="recipient-mail" class="col-form-label">Ваш email:</label>
          <input type="email" v-model="obj.userEmail"  name="email" id="recipient-mail" class="form-control" placeholder="example@mail.ru">
        </div>
        <div class="form-group">
          <label for="message-text" class="col-form-label">Сообщение:</label>
          <textarea name="message" v-model="obj.userMessage" id="message-text" class="form-control"></textarea>
        </div>
        <button @click.prevent="addToStore()" type="submit">submit</button>
      </form>
    </div>
    <h3>list of contacts</h3>
    <div class="contacts-list">
      <div class="list-element" v-for="contact in allContacts" :key="contact.id">
        id: {{contact.id}} <br> name: {{contact.name}}<br/> email: {{contact.email}}<br/> message: {{contact.message}}
      </div>
    </div>
  </div>

</template>
<script>
  import { mapMutations, mapGetters, mapActions } from 'vuex'
  export default {
    data() {
      return {
        obj: {
          userName: '',
          userEmail: '',
          userMessage: ''
        }
      }
    },
   mounted() {
     console.log(this.showGetters)
   },
    created() {
       this.initializeData()
    },
    methods: {
      ...mapActions({
        initializeData: 'contacts/initializeData',
        addNewContact: 'contacts/addNewContact'
      }),
      addToStore() {
        this.addNewContact(this.obj)
      },
    },
    computed: {
      ...mapGetters({
        allContacts: 'contacts/allContacts',
      }),
      showGetters () {
        return this.allContacts
      }

    },

  }
</script>


итак, может ли кто-нибудь помочь понять, в чем же дело?

У вопроса есть решение - Посмотреть?

Ответы - проблемы с визуализацией данных Vuex / problems with Vuex data rendering

skirtle

14.03.2020 07:46:48

У вас есть несовпадающие имена полей.

Внутри obj вы назвали их userName, userEmail и userMessage. Для всех остальных контактов вы назвали их name, email и message.

Вы можете использовать разные имена, если хотите, но где-то вам придется сопоставить одно с другим, чтобы все они были одинаковыми в пределах массива.

Вы должны быть в состоянии подтвердить это с помощью Vue Devtools. Первые 3 контакта будут иметь поля, отличные от полей только что добавленного контакта.

Закрыть X