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[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 }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“Vuex之理解state的用法实例”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
2024年11月16日
2024年11月16日
- 孙悦2024-时光音乐会[金蜂][WAV+CUE]
- 秦宇子.2020-#YUZI【海蝶】【FLAC分轨】
- 苏有朋.1994-这般发生【华纳】【WAV+CUE】
- 小虎队.1990-红蜻蜓【飞碟】【WAV+CUE】
- 雷婷《寂寞烟火HQⅡ》头版限量[低速原抓WAV+CUE][1G]
- 赵传1996《黑暗英雄》台湾首版[WAV+CUE][1G]
- 张敬轩2005《我的梦想我的路》几何娱乐[WAV+CUE][1G]
- 群星《人到四十男儿情(SRS+WIZOR)》[原抓WAV+CUE]
- 马久越《上善若水HQCDII》[低速原抓WAV+CUE]
- 龚玥《女儿情思》6N纯银SQCD【WAV+CUE】
- 张惠妹《你在看我吗》大碟15 金牌大风[WAV+CUE][1G]
- 群星《左耳·听见爱情》星文唱片[WAV+CUE][1G]
- 群星《抖音嗨疯-DISCO英文版》[WAV+CUE][1G]
- 群星.1990-情义无价(TP版)【中唱】【WAV+CUE】
- 马兆骏.1990-心情·七月【滚石】【WAV+CUE】