vuex之mapMutation的使用

1.每个 mutation 都有一个字符串的 事件类型 (type) 和 一个 回调函数 (handler)。这个回调函数就是我们实际进行状态更改的地方,并且它会接受 state 作为第一个参数。

mutations {
    increment(state){
        //改变状态的操作
    }
}

我们这里只是定义了一个可以改变状态的函数(mutation),我们还需要调用(触发)这个函数。而触发这个函数我们不能直接调用函数,而是要通过commit来触发这个函数。

this.$store.commit('increment')

括号里面的就是我们自己定义的事件类型(type)。这样才真正触发了这个mutation,状态才改变了。没有其他方式可以提交mutation。

2.我们还可以像普通函数一样传入额外的参数。

mutations {
    increment(state,payload){
        //改变状态的操作
    }
}

payload就像普通函数的参数一样使用。但是通常情况下payload应该是一个对象,方便阅读。

3.使用常量替代 Mutation 事件类型

即定义一个mutations-type.js文件用于存放mutations的事件类型。

// mutation-types.js
export const SOME_MUTATION = 'SOME_MUTATION'

然后在mutations.js文件中定义一系列的mutation

//mutations.js
import * as type from './mutation-type'
mutations:{
    [type.SOME_MUTATION](state){
        //改变状态的操作
    }
}

4.Mutation 必须是同步函数

5....mapMutations

<button @click="increment">
//自定义事件类型与mutation的事件类型同名
...mapMutations([
    'increment'
])

//将this.increment() 映射为 this.$store.commit("increment")




<button @click="add">
//自定义事件类型为add,mutation事件类型为increment
...mapMutations({
    add: 'increment'
})

//将this.add() 映射为 this.$store.commit("increment")

实际上是这样的

methods: {
    increment() {
        this.$store.commit("increment")
    }
}


methods: {
    add() {
        this.$store.commit("increment")
    }
}

 

  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值