Vuex之理解state

理解state

1.什么是statevue

  • 上一篇文章说了,Vuex就是提供一个仓库,仓库里面放了不少对象。其中state就是数据源存放地,对应于与通常Vue对象里面的data(后面讲到的actionsmutations对应于methods)。vuex

  • 响应书存储state里面存放的数据是响应式的,Vue组件从store中读取数据,如果store中的数据发生改变,依赖这个数据的组件也会发生更新。(这里“状态”=“数据”),也就是是说数据和视图是同步的。segmentfault


2.局部状态数组

  • 获取:在Vue组件中获取数据,最直接的能够经过计算属性中获取;app

  • 组件仍然能够保存局部状态:虽说VuexStore仓库让咱们同一管理数据变得更加方便,可是代码一多也会变得冗长,有些组件的数据是本身严格自用,咱们能够将state放在组件自身,做为局部数据,专供此组件使用,其余的组件不能用。函数


3.mapStatethis

  • mapState的做用是把全局的 stategetters 映射到当前组件的 computed 计算属性中,this.$store.statecode

  • 使用示例orm

    import {mapState} from 'vuex' 
     export default {
      computer :
      mapState({
       count: state => state.count,
        'count' // 映射 this.count 为 store.state.count
      })
    }
  • 看看源码对象

    export function mapState (states) {
       const res = {}   //定义一个对象
       normalizeMap(states).forEach(({ key, val }) => {
        // 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
       }
相关文章
相关标签/搜索