Vue进阶(幺肆捌):Vuex辅助函数详解
【摘要】 一般情况下,如果需要访问vuex.store中state存放的数据,需要使用this.$store.state.属性名形式。显然,这样访问数据形式代码略显繁杂,辅助函数应运而生。
辅助函数
通过辅助函数mapGetters、mapState、mapActions、mapMutations,把vuex.store中的属性映射到vue实例身上,这样在vue实例中就能访问...
一般情况下,如果需要访问vuex.store中state存放的数据,需要使用this.$store.state.属性名形式。显然,这样访问数据形式代码略显繁杂,辅助函数应运而生。
辅助函数
通过辅助函数mapGetters、mapState、mapActions、mapMutations,把vuex.store中的属性映射到vue实例身上,这样在vue实例中就能访问vuex.store中的属性了,对于操作vuex.store就变得非常方便。
state辅助函数为mapState,actions辅助函数为mapActions,mutations辅助函数为mapMutations。(Vuex实例身上有mapState、mapActions、mapMutations属性,属性值都是函数)
如何使用辅助函数
-
需要在当前组件中引入
Vuex。 -
通过
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里面有getters、setters方法;data中的数据也是响应式的,因为里面也有getters和setters方法。
在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,另外一个是需要传递的参数。
理解state、actions、mutations,可以参考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,
....
}
mapState、mapGetters、mapMutations、mapActions第一个参数是字符串(命名空间名称),第二个参数是数组(不需要重命名)/对象(需要重命名)。
mapXXXs('命名空间名称',['属性名1','属性名2'])
mapXXXs('命名空间名称',{ '组件中的新名称1':'Vuex中的原名称1', '组件中的新名称2':'Vuex中的原名称2',
})
拓展阅读
《Vue进阶(二十七):Vuex之getters,mapGetters,…mapGetters详解》
文章来源: shq5785.blog.csdn.net,作者:No Silver Bullet,版权归原作者所有,如需转载,请联系作者。
原文链接:shq5785.blog.csdn.net/article/details/110957331
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
作者其他文章



评论(0)