• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Vuex之理解state的用法实例

vue 搞代码 4年前 (2022-01-08) 19次浏览 已收录 0个评论

本篇文章主要介绍了Vuex之理解state的用法实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

1.什么是state?

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

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

2.局部状态

获取:在Vue组件中获取数据,最直接的可以通过计算属性中获取;

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

3.mapState

mapState的作用是把全局的 state getters 映射到当前组件的 computed 计算属性中,this.$store.state
本文来源gaodaimacom搞#代%码@网-

使用示例

 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 } 

以上就是Vuex之理解state的用法实例的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Vuex之理解state的用法实例

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址