Vuex之理解state的用法实例
1.什么是state?
上一篇文章说了,Vuex就是提供一个仓库,仓库里面放了很多对象。其中state就是数据源存放地,对应于与一般Vue对象里面的data(后面讲到的actions和mutations对应于methods)。
响应书存储:state里面存放的数据是响应式的,Vue组件从store中读取数据,若是store中的数据发生改变,依赖这个数据的组件也会发生更新。(这里“状态”=“数据”),也就是是说数据和视图是同步的。
2.局部状态
获取:在Vue组件中获取数据,最直接的可以通过计算属性中获取;
组件仍然可以保存局部状态:虽然说Vuex的Store仓库让我们同一管理数据变得更加方便,但是代码一多也会变得冗长,有些组件的数据是自己严格自用,我们可以将state放在组件自身,作为局部数据,专供此组件使用,其他的组件不能用。
3.mapState
mapState的作用是把全局的state和getters映射到当前组件的computed计算属性中,this.$store.state。
使用示例
import{mapState}from'vuex' exportdefault{ computer: mapState({ count:state=>state.count, 'count'//映射this.count为store.state.count }) }
看看源码
exportfunctionmapState(states){ constres={}//定义一个对象 normalizeMap(states).forEach(({key,val})=>{ //normalizeMap()函数初始化states数据 res[key]=functionmappedState(){ returntypeofval==='function' //判断val是否是函数 ?val.call(this,this.$store.state,this.$store.getters) //若val是函数,将store的state和getters作为参数,返回值作为mappedState的返回值 :this.$store.state[val]}}) returnres//返回的是一个函数 } //初始化方法 functionnormalizeMap(map){ returnArray.isArray(map)//判断state是否是数组 ?map.map(key=>({key,val:key})) //是数组的话,调用map方法,将每一个数组元素转换成{key,val:key} :Object.keys(map).map(key=>({key,val:map[key]})) //否则就是对象,遍历对象,将每一个val变成val:key }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。