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之前,要导入这个辅助函数。
1 | import { mapState } from 'vuex'
|
登录后复制
使用方式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 | <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 &#39;vuex&#39;
export default {
data () {
return {
str: '国籍',
dataCount: this. $store .state. count
}
},
computed: mapState({
count : ' count ',
sex: (state) => state.sex,
from: function (state) {
return this.str + ':' + state.from
},
myCmpted: function () {
return '测试' + this.str
}
}),
methods: {
increment () {
this. $store .commit('increment')
},
decrement () {
this. $store .commit('decrement')
}
}
}
</script>
|
登录后复制
computed
可以接收mapState
函数的返回值,你可以用代码中的三种方式去接收store中
的值,具体可以看注释。
如果我在后面想使用mapState怎么办?其实很简单
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | computed:{
fn1(){ return ...},
fn2(){ return ...},
fn3(){ return ...}
........
}
computed:mapState({
fn1(){ return ...},
fn2(){ return ...},
fn3(){ return ...}
......
count :' count '
})
|
登录后复制
4.对象展开运算符
…mapState并不是mapState的扩展,而是…对象展开符的扩展 。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | computed:{
fn1(){ return ...},
fn2(){ return ...},
fn3(){ return ...}
........
}
computed:{
fn1(){ return ...},
fn2(){ return ...},
fn3(){ return ...}
......
...mapState({
count :' count '
})
|
登录后复制
mapState
、mapGetters
、mapActions
、mapMutations
的使用方法大同小异。。。
【相关推荐:《vue.js教程》】
以上是vue的辅助函数有哪些的详细内容。更多信息请关注PHP中文网其他相关文章!