Live2d Test Env

辅助函数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(item.id)'>-</button>
<input type="number" class="fl" v-model="item.count" >
<button class="fl" @click='increase(item.id)'>+</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)
//同理
}
}

以上。

posted @   致爱丽丝  阅读(12065)  评论(1编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
点击右上角即可分享
微信分享提示