I want to set Vuex mutations as follows:
export default {
props: {
store: String
},
methods: {
...mapMutations({
changeModel: `${this.store}/changeModel`
})
}
}
But I catch the error:
Uncaught TypeError: Cannot read property 'store' of undefined
How do I correctly use props inside the module mutation name?
I want to map this.$store.commit('form1/changeModel')
, where form1
is set from props.
I think there is no way to bind this on mapActions. But you can call it with
$store.dispatch
It is not exaclty the solution that you asked but its effect is the same. As the mutation is a variable parameter, it is obvious to put it into a function as an input parameter instead of changing the mutation name. I would create an action in the store like this:
And I would use this action in the component passing the mutationName into it.
Vuex helper
mapMutations
can be used with a function which works withthis
.There does not seem to be a doc for this, but the Vuex unit test helpers.spec.js illustrates the pattern.
As a bonus, the function allows passing a parameter to the mutation, which is a common requirement.
Your code changes would be:
The call within your component is just
changeModel()
- mapMutations is taking care of injecting thecommit
parameter.Note, I am not sure this is adding much except some extra noise (compared to a simple
this.$store.commit()
), but perhaps your requirement is more complicated than the example code.