Vuex之理解state的用法实例

网友投稿 342 2023-05-22


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'

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[viINJlRal]}})

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

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:bootstrap常用组件之头部导航实现代码
下一篇:详解vue表单验证组件 v
相关文章

 发表评论

暂时没有评论,来抢沙发吧~