mutations vuex 调用_Vuex之理解Mutations的用法实例

1.什么是mutations?

通俗的理解mutations,里面装着一些改变数据方法的集合,这是Veux设计很重要的一点,就是把处理数据逻辑方法全部放在mutations里面,使得数据和视图分离。

2.怎么用mutations?

mutation结构:每一个mutation都有一个字符串类型的事件类型(type)和回调函数(handler),也可以理解为{type:handler()},这和订阅发布有点类似。先注册事件,当触发响应类型的时候调用handker(),调用type的时候需要用到store.commit方法。

store.commit('increment') //调用type,触发handler(state)

载荷(payload):简单的理解就是往handler(stage)中传参handler(stage,pryload);一般是个对象。

const store = new Vuex.Store({

state: { ... },mutations: {

// 我们可以使用 ES2015 风格的计算属性命名功能来使用一个常量作为函数名

[SOME_MUTATION] (state) {

// mutate state

}

}

})

commit:提交可以在组件中使用this.$store.commit('xxx') 提交 mutation,或者使用 mapMutations辅助函数将组件中的 methods映射为 store.commit调用(需要在根节点注入 store)。

export default {

methods: {

...mapMutations([

'increment' // 映射 this.increment() 为

this.$store.commit('increment')]),...mapMutations({

add: 'increment' // 映射 this.add() 为

this.$store.commit('increment')

})}}

3.源码分析

registerMutation:初始化mutation

commit:调用mutation

{

entry.forEach(function commitIterator (handler) {

// 遍历type对应的mutation对象数组,执行handle(payload)方法

//也就是开始执行wrappedMutationHandler(handler)

handler(payload)

})

})

if (!options || !options.silent) {

this._subscribers.forEach(sub => sub(mutation,this.state))

//把mutation和根state作为参数传入

}

}

subscribers:订阅store的mutation

{

const i = subs.indexOf(fn)

if (i > -1) {

subs.splice(i,1)

}

}

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值