Vuex的辅助函数mapState, mapActions, mapMutations用法

直接代码解说

store/index.js (简单书写)

export default new Vuex.Store({
    state: {
        add: 10
    },
    mutations: {
        change(state,a) {
            state.add += a
        }
    }
})

在一般的情况下,我们想要拿到add这个值,就需要使用this. $store.state.add来获取,但是这样的代码片段太长了

前提:

import { mapState, mapActions, mapMutations} from 'vuex'
//使用都分为两种方式:对象和数组,但是自我推荐,使用对象的形式,更加有利于理解

mapState的使用

computed: mapState({
    'add', 'add',    // 第一种写法
    'add': state => state.add    // 第二种写法
})
//更加简便
computed: {
    ...mapState(['add'])  //必须要加冒号
}

mapMutations的使用

//调用Mutations 需要时使用 this.$store.commit('change', 1) 这样的

//第一种方式,使用数组的形式
...mapMutations(['change']), // 会将 this.change 映射成 this.$store.commit('change') 
//第二种方式,使用对象的形式
...mapMutations({
    'change': 'change'  //前面这个属性可以随便写,但是后面的属性值要与mutations中对应起来
 })
//传参: 跟普通的方法一样,直接把参数写在调用函数的括号里,就OK了。

mapActions的使用(对异步函数的操作)

//调用Actions 需要时使用 this.$store.dispatch('asyn', 1) 这样的

//第一种方式,使用数组的形式
...mapActions(['asyn']), // 会将 this.asyn 映射成 this.$store.dispatch('asyn') 
//第二种方式,使用对象的形式
...mapActions({
    'asyn': 'asyn'  //前面这个属性可以随便写,但是后面的属性值要与actions中对应起来
 })
posted @ 2020-07-10 15:48  coder_xyf  阅读(359)  评论(0编辑  收藏  举报