vue的辅助函数有哪些
vue的辅助函数有:1、mapState,将全局状态管理的state值映射到组件的计算属性;2、mapGetters,将全局状态管理的getters值映射到组件的计算属性;3、mapActions;4、mapMutations。
本教程操作环境:windows7系统、vue2.9.6版,DELL G3电脑。
1.Vue的辅助函数
mapState、mapGetters、mapActions、mapMutations
mapState 将全局状态管理的state值映射到组件的计算属性
mapGetters 将全局状态管理的getters值映射到组件的计算属性
mapMutation 将mutation的值映射到方法里
mapActions 将actions里的值映射到方法里
2.mapState 辅助函数
mapState
是什么?官方的解释是:
当一个组件需要获取多个状态时候,将这些状态都声明为计算属性会有些重复和冗余。为了解决这个问题,我们可以使用 mapState 辅助函数帮助我们生成计算属性,让你少按几次键
当初在看到这个解释的时候可能觉得非常空洞,难以理解。生成计算属性是什么?少按几次键???
mapState是state的语法糖,什么是语法糖?我对语法糖的理解就是,我明明已经对一种操作很熟练了,并且这种操作也不存在什么问题,为什么要用所谓的"更好,更好的操作"?,用了一段时间后,真香!
3.如何使用
在使用mapState之前,要导入这个辅助函数。
import { mapState } from 'vuex'
使用方式
<template> <div id="example"> <button @click="decrement">-</button> {{count}} {{dataCount}} <button @click="increment">+</button> <div>{{sex}}</div> <div>{{from}}</div> <div>{{myCmpted}}</div> </div> </template> <script> import { mapState } from 'vuex' export default { data () { return { str: '国籍', dataCount: this.$store.state.count } }, computed: mapState({ count: 'count', // 第一种写法 sex: (state) => state.sex, // 第二种写法 from: function (state) { // 用普通函数this指向vue实例,要注意 return this.str + ':' + state.from }, // 注意下面的写法看起来和上面相同,事实上箭头函数的this指针并没有指向vue实例,因此不要滥用箭头函数 // from: (state) => this.str + ':' + state.from myCmpted: function () { // 这里不需要state,测试一下computed的原有用法 return '测试' + this.str } }), methods: { increment () { this.$store.commit('increment') }, decrement () { this.$store.commit('decrement') } } } </script>
computed
可以接收mapState
函数的返回值,你可以用代码中的三种方式去接收store中
的值,具体可以看注释。
如果我在后面想使用mapState怎么办?其实很简单
//之前的computed computed:{ fn1(){ return ...}, fn2(){ return ...}, fn3(){ return ...} ........ } //引入mapState辅助函数之后 computed:mapState({ //先复制粘贴 fn1(){ return ...}, fn2(){ return ...}, fn3(){ return ...} ...... //再维护vuex count:'count' })
4.对象展开运算符
…mapState并不是mapState的扩展,而是…对象展开符的扩展 。
//之前的computed computed:{ fn1(){ return ...}, fn2(){ return ...}, fn3(){ return ...} ........ } //引入mapState辅助函数之后 computed:{ //原来的继续保留 fn1(){ return ...}, fn2(){ return ...}, fn3(){ return ...} ...... //再维护vuex ...mapState({ //这里的...不是省略号了,是对象扩展符 count:'count' })
mapState
、mapGetters
、mapActions
、mapMutations
的使用方法大同小异。。。
【相关推荐:《vue.js教程》】
以上就是vue的辅助函数有哪些的详细内容,更多请关注其它相关文章!
上一篇: Vue入门:todolist实例带你入门全局组件和局部组件
下一篇: php怎么删除指定下标的数组值
推荐阅读
-
MySQL数据库接口在VC中的实际应用有哪些?
-
女生学地质学合适吗?地质学最适合女生的专业有哪些?
-
MATLAB和Python 相互无法替代的地方有哪些,对于以后一直做科研的人,两种语言到底哪家强?
-
javascript - php 有什么函数是可以根据文件名称,来获取这个文件的全路径的吗?或者js 怎么获取文件的全路径?
-
有一个函数是读取mysql的资源 是一次读取全部 不用循环的函数!
-
有哪些你不知道的Python小工具
-
C#/.NET/.NET Core定时任务调度的方法或者组件有哪些--Timer,FluentScheduler还是...
-
php 函数当中实现相同功能但是速度有差异的有哪些,为什么速度会有差异?
-
Python的主要应用领域有哪些?Python的介绍
-
有哪些大型公司在使用 Python?有哪些知名项目是主要由 Python 写成的?