前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vuex之mutation

Vuex之mutation

作者头像
wade
发布2020-04-24 17:25:37
5410
发布2020-04-24 17:25:37
举报
文章被收录于专栏:coding个人笔记coding个人笔记

我们已经可以在组建中使用store里面的数据了,那么我们要怎么修改这个数据呢?vuex提供了mutation,官网上说:

更改 Vuex 的 store 中的状态的唯一方法是提交 mutation。Vuex 中的 mutation 非常类似于事件:每个 mutation 都有一个字符串的 事件类型 (type) 和 一个 回调函数 (handler)。这个回调函数就是我们实际进行状态更改的地方,并且它会接受 state 作为第一个参数。

简单来说mutations里面是一个一个的方法,参数第一个就是state:

代码语言:javascript
复制
export default { 
    scoreChange(state){ 
         state.score++; 
     }
}

调用的话官网说:

你不能直接调用一个 mutation handler。这个选项更像是事件注册:“当触发一个类型为 increment 的 mutation 时,调用此函数。”要唤醒一个 mutation handler,你需要以相应的 type 调用 store.commit 方法,简单来说就是:

this.$store.commit('scoreChange');

官网所说的type就是mutation里面定义的方法名字。

你可以向 store.commit 传入额外的参数,即 mutation 的 载荷(payload):

代码语言:javascript
复制
export default { 
    scoreChange(state, num){ 
       state.score += num; 
     }
}

调用:

this.$store.commit('scoreChange', 10);

官网有几个建议:

参数最好是一个对象。

Mutation 需遵守 Vue 的响应规则,具体可以看官网。

使用常量替代 Mutation 事件类型,本人不是很喜欢,有兴趣的可以自己去看看。

Mutation 必须是同步函数,但其实试过的都知道就算是异步函数也是可以实现状态的修改,那为什么要都是同步的呢?主要是为了调试,使用devtools的时候采用异步不好追踪数据。一定要注意,mutation不能是异步最主要的就是为了调试,而不是不能修改状态。

辅助函数mapMutations:

引入:import { mapState, mapMutations } from 'vuex'

两种方式注入:

...mapMutations([ 'scoreChange',]),

...mapMutations({ add: 'scoreChange'})

调用:

this.add(10);

this.scoreChange(10);

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-12-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 coding个人笔记 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档