如何使用他的数据实时更新制作vuex和组件

问题描述 投票:0回答:1

有两个独立的组件。一个按钮和一个表单。我可以通过按下按钮来“ $ store.dispatch”对vuex的操作

addWorkerSubmit: async function () {
      ...
      await this.$store.dispatch('workermanage/addWorkerSubmit', formData)
    }

在vuex中,有一个可以发布后端功能以将数据添加到数据库中的功能

const actions = {
  ...
  async addWorkerSubmit ({ commit }, formData) {
    let { status, data: { code, msg } } = await axios.post(`/manager/worker_manage/addStaff`, formData, {
      headers: { 'content-type': 'multipart/form-data' }
    })
    if (status === 200 & code === 0) {
      ...
    }
  }
}

但是当新数据插入数据库时​​,表单组件无法重新加载此新数据。仅刷新网页,新数据即可添加到表格中

   <Table
        border
        height="700"
        :columns="peopleColumns"
        :data="persons"
      >
        ...
   </Table>
...mapState({ persons: state => state.workermanage.staff.staff })

刷新网页之前,我在“ state.workermanage.staff.staff”中仅检查了原始数据,没有检查新添加的数据

[state.workermanage.staff.staff]中的数据是通过“ nuxtServerInit”函数从数据库中获取的

actions: {
      async nuxtServerInit ({ commit }, { req, app }) {
        let { status, data: { code, result } } = await app.$axios.get('/manager/worker_manage/getStaff')
        commit('workermanage/setStaff'...
    }

我应该怎么做才能使表中的数据和“ state.workermanage.staff.staff”实时更新,谢谢

javascript vue.js vuex real-time nuxt.js
1个回答
0
投票

在操作addWorkerSubmit中提交一个突变“ workermanage / addStaff”。后端可以返回增加的人员吗?如果是这样:

const actions = {
  ...
  async addWorkerSubmit ({ commit }, formData) {
    let { status, data: { code, msg, staff } } = await axios.post(`/manager/worker_manage/addStaff`, formData, {
      headers: { 'content-type': 'multipart/form-data' }
    })
    if (status === 200 & code === 0) {
      commit('workermanage/addStaff', staff)
    }
  }
}

const mutations = {
    addStaff(state, payload) {
        state.staffs.push(payload)
    }
}

如果后端不返回添加的人员。您可以查询更新的列表(与nuxtServerInit相同的操作),也可以从formData获取添加的人员

© www.soinside.com 2019 - 2024. All rights reserved.