使用vuex中的 mapmutations 辅助函数时怎么传递参数
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用vuex中的 mapmutations 辅助函数时怎么传递参数相关的知识,希望对你有一定的参考价值。
this.increment( amount: 10 ) 或 this.add( amount: 10 )用this.$store.commit(\'xxx\',obj)时可以传递一个obj,那么用mapMutations()时怎么传递一个额外的参数。 参考技术A 直接把参数带在click后面, v-on:click="increment
(amount:10)" ,后面
methods:
...mapMutations([
'increment'
])
vuex中的辅助函数mapMutations详细解析
mapMutations是vuex的mutation的辅助函数,用于在组件中映射mutation内的方法,以便在该组件中直接使用mutation里的方法 (说白了,就是一语法糖)
1.在组件中导入vuex中的mapMutations:
import { mapMutations } from ‘vuex‘
2.在组件中导入mutation里的方法名:
...mapMutations([ //使用es6的拓展运算符
‘INCREASE_SHOPCART‘,
‘DECREASE_SHOPCART‘
])
//约定将mutation里的方法名为大写,并且导入时要给其加上引号
这一步,是将mutation里的函数映射到组件里,在组件里 :
this.INCREASE_SHOPCART === this.$store.commit(‘INCREASE_SHOPCART‘) //true
在有参数的情况下,mutation的state默认参数可以省略 :
this.INCREASE_SHOPCART(id) === this.$store.commit(‘INCREASE_SHOPCART‘,id) //true
举个栗子:点击btn按钮增减商品数量
- 组件dom :
//shopCart.vue
//template
<button class="fl" @click=‘decrease‘>-</button>
<input type="number" class="fl" v-model="item.count" >
<button class="fl" @click=‘increase‘>+</button>
- mutations :
//mutations.js
INCREASE_SHOPCART(state,id){
state.shopCartData.forEach(e=>{
if(e.id === id){
e.count ++
}
})
},
DECREASE_SHOPCART(state,id){
state.shopCartData.forEach(e=>{
if(e.id === id && e.count >1){
e.count --
}
})
}
- 组件里的methods:
import { mapMutations } from ‘vuex‘ // 先从vuex里导入 mapMutations
methods:{
...mapMutations([
‘INCREASE_SHOPCART‘, //将mutation里的方法映射到该组件内
‘DECREASE_SHOPCART‘ //等同于this.$store.commit(‘DECREASE_SHOPCART‘)
]),
increase(id){
this.INCREASE_SHOPCART(id)
//由于上一步已经将mutation映射到组件内,所以组件可以直接调用INCREASE_SHOPCART
}
decrease(id){
this.DECREASE_SHOPCART(id)
//同理
}
}
以上。
以上是关于使用vuex中的 mapmutations 辅助函数时怎么传递参数的主要内容,如果未能解决你的问题,请参考以下文章
使用vuex中的 mapmutations 辅助函数时怎么传递参数
使用Vuex中的 mapMutations 辅助函数时怎么传递参数
关于mapState和mapMutations和mapGetters 和mapActions辅助函数的用法及作用-----mapState