Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
menu search
person
Welcome To Ask or Share your Answers For Others

Categories

I have a form and i use v-model for that to connect it to computed , and computed use get and set with object in VueX , when form is submitted that object will pushed into main array , the problem is that , even after push the connection between form input and pushed object in array will not disconnect and when new form submited the old will change ,

this is computed that v-modeled whith text input

  computed: {
    name: {
      get() {
        return this.$store.state.item.name
      },
      set(value) {
        this.$store.commit('mut_up_name', value)
      },
    },

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
237 views
Welcome To Ask or Share your Answers For Others

1 Answer

It is better to avoid changing the state directly inside of vuex actions and if you would like to change the value of the input, use @input instead and dispatch your actions from there. If you would like mutate multiple actions, then you can take a look from my approach:

Template:

<template>
  <some-input-component :value="name" @input="inputHandler($event)"/>
</template>

Script:

computed: {
  name() {
    return this.$store.state.item.name;
  },
},
methods: {
  inputHandler(e) {
    this.$store.dispatch('add_item', e);
  },
},

in the vuex:

state: {
  item: {
    name: '',
  },
  someArray: [],
},
actions: {
  add_item: ({ commit }, e) => {
    commit('mutate_name', e);
    commit('push_item', e);
  }
},
mutations: {
  mutate_name: (state, value) => {
    state.item.name = value;
  },
  push_item: (state, obj) => {
    state.someArray.push(obj);
  },
},

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
...