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
。
使用示例
state.count,'count' // 映射 this.count 为 store.state.count
})
}
看看源码
{
// normalizeMap()函数初始化states数据
res[key] = function mappedState () {
return typeof val === 'function'
// 判断val是否是函数
? val.call(this,this.$store.state,this.$store.getters)
// 若val是函数,将store的state和getters作为参数,返回值作为mapped State的返回值
: this.$store.state[val]}})
return res // 返回的是一个函数
}
//初始化方法
function normalizeMap (map) {
return Array.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
}