Ao usar o Vuex no modo estrito, pode ser um pouco complicado usar v-model
em um pedaço do estado que pertence ao Vuex:
<input v-model="obj.message">
Assuming obj
is a computed property that returns an Object from the store, the v-model
here will attempt to directly mutate obj.message
when the user types in the input. In strict mode, this will result in an error because the mutation is not performed inside an explicit Vuex mutation handler.
Assumindo que obj
é um dado computado que retorna um Objeto do store, o v-model
aqui tentará alterar diretamente o obj.message
quando o usuário digitar alguma coisa. No modo estrito, isso resultará em um erro porque a mutação não é executada dentro de um manipulador explícito de mutação Vuex.
O "modo Vuex" para lidar com isso é vinculando o valor do(s) <input>
's e chamar uma ação no evento input
ou change
:
<input :value="message" @input="updateMessage">
// ...
computed: {
...mapState({
message: state => state.obj.message
})
},
methods: {
updateMessage (e) {
this.$store.commit('updateMessage', e.target.value)
}
}
E aqui está o manipulador de mutação:
// ...
mutations: {
updateMessage (state, message) {
state.obj.message = message
}
}
É certo que o acima é um pouco mais verboso do que o v-model
+ estado local, e também perdemos alguns dos recursos úteis do v-model
. Uma abordagem alternativa está usando uma dado computado bidirecional com um setter:
<input v-model="message">
// ...
computed: {
message: {
get () {
return this.$store.state.obj.message
},
set (value) {
this.$store.commit('updateMessage', value)
}
}
}