写点什么

Vue 进阶(幺肆捌):Vuex 辅助函数详解

用户头像
华强
关注
发布于: 3 小时前

一般情况下,如果需要访问vuex.storestate存放的数据,需要使用this.$store.state.属性名形式。显然,这样访问数据形式代码略显繁杂,辅助函数应运而生。

辅助函数

通过辅助函数mapGettersmapStatemapActionsmapMutations,把vuex.store中的属性映射到vue实例身上,这样在vue实例中就能访问vuex.store中的属性了,对于操作vuex.store就变得非常方便。


state辅助函数为mapStateactions辅助函数为mapActionsmutations辅助函数为mapMutations。(Vuex实例身上有mapStatemapActionsmapMutations属性,属性值都是函数)

如何使用辅助函数

  1. 需要在当前组件中引入Vuex

  2. 通过Vuex来调用辅助函数。

辅助函数如何去映射 vuex.store 中的属性

1、mapState:把 state 属性映射到 computed 身上

computed:{   ...Vuex.mapState({      input:state=>state.inputVal,      n:state=>state.n  })   }
复制代码


简写形式如下:


import { mapGetters } from 'vuex'computed:{  ...mapGetters(['input', 'n'])}
复制代码


state:用来存储公共状态, state中存储的数据都是响应式的。


响应式原因:state里面有getterssetters方法;data中的数据也是响应式的,因为里面也有getterssetters方法。


computed属性中来接收state中的数据,接收方式有 2 种(数组和对象,推荐对象).


优点:


  • 本身key值是别名,要的是val值,key的值 a 和 val="a"一样就行,随意写。减少state里面长的属性名。

  • 可以在函数内部查看state中的数据,数组方式的话,必须按照state中的属性名。


  computed:Vuex.mapState({    key:state=>state.属性  })
复制代码


如果自身组件也需要使用computed的话,通过解构赋值去解构出来。


  computed:{    ...Vuex.mapState({       key:state=>state.属性    })  }
复制代码

2、mapAcions:把 actions 方法映射到 methods 中

methods:{        ...Vuex.mapActions({            add:"handleTodoAdd",    //val为actions里面的方法名称            change:"handleInput"             })    }
复制代码


简写形式如下:


import { mapActions } from 'vuex'methods:{    ...mapActions(['add', 'change'])}
复制代码


add、change 为action方法别名,直接代用 add 和 change 方法就行,不过要记得在 actions 里面做完数据业务逻辑的操作。


等价于如下的函数调用,


methods: {  handleInput(e){               let val = e.target.value;    this.$store.dispatch("handleInput",val )  },  handleAdd(){    this.$store.dispatch("handleTodoAdd")  }}
复制代码


actions里面的函数主要用来处理异步的函数以及一些业务逻辑,每一个函数里面都有一个形参,这个形参是一个对象,里面有一个commit方法,这个方法用来触发mutations里面的方法。

3、mapMutations:把 mutations 里面的方法映射到 methods 中

只是做简单的数据修改(例如 n++),它没有涉及到数据处理,没有用到业务逻辑或者异步函数,可以直接调用mutations里的方法修改数据。


methods:{        ...Vuex.mapMutations({            handleAdd:"handlMutationseAdd"        })    }
复制代码


简写形式如下:


import { mapMutations} from 'vuex'methods:{    ...mapMutations(['handleAdd'])}
复制代码


mutations里面的函数主要用来修改state中的数据。mutations里面的所有方法都会有 2 个参数,一个是store中的state,另外一个是需要传递的参数。


理解stateactionsmutations,可以参考MVC框架。


  • state看成一个数据库,只是它是响应式的,刷新页面数据就会改变;

  • actions看成 controller 层,做数据的业务逻辑;

  • mutations看成 model 层,做数据的增删改查操作。

4、mapGetters:把 getters 属性映射到 computed 身上

 computed:{        ...Vuex.mapGetters({            NumN:"NumN"        })    }
复制代码


简写形式如下:


import { mapGetters} from 'vuex'methods:{    ...mapGetters(['NumN'])}
复制代码


getters类似于组件里面computed,同时也监听属性的变化,当state中的属性发生改变的时候就会触发getters里面的方法。getters里面的每一个方法中都会有一个参数 state

5、modules 属性: 模块

把公共的状态按照模块进行划分 1、每个模块都相当于一个小型的 Vuex 2、每个模块里面都会有state getters actions mutations 3、切记在导出模块的时候加一个 namespaced:true 主要的作用是将每个模块都有独立命名空间 4、namespace:true在多人协作开发的时候,可能子模块和主模块中的函数名字会相同,这样在调用函数的时候,相同名字的函数都会被调用,就会发生问题。为了解决这个问题,导出模块的时候要加namespace:true.  那么怎么调用子模块中的函数呢?假如我的子模块名字为 todo.js。 函数名字就需要改成 todo/函数名字。输出模块后的 store 实例如下图所示:  



可以看到模块化后,store 实例的 state 属性的访问方式也改变了,this.$store.state.todo.inputVal


可以简单总结一下辅助函数通过 vuex 使用,比喻成映射关系为:


  • mapState/mapGettes--->computed

  • mapAcions/mapMutations---->methods

命名空间

模块开启命名空间后,享有独自的命名空间。示例代码如下:


export default {  namespaced: true,  ....}
复制代码


mapStatemapGettersmapMutationsmapActions第一个参数是字符串(命名空间名称),第二个参数是数组(不需要重命名)/对象(需要重命名)。


mapXXXs('命名空间名称',['属性名1','属性名2'])
mapXXXs('命名空间名称',{
  '组件中的新名称1':'Vuex中的原名称1',
  '组件中的新名称2':'Vuex中的原名称2',
})
复制代码

拓展阅读

Vue进阶(二十七):Vuex之getters,mapGetters,...mapGetters详解


Vue进阶(四十三):Vuex之Mutations详解

发布于: 3 小时前阅读数: 3
用户头像

华强

关注

No Silver Bullet 2021.07.09 加入

岂曰无衣 与子同袍

评论

发布
暂无评论
Vue进阶(幺肆捌):Vuex辅助函数详解