Vuex之理解state的用法实例


Posted in Javascript onApril 19, 2017

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

使用示例

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
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery入门第一课 jQuery选择符
Mar 14 Javascript
javascript实现信息的显示和隐藏如注册页面
Dec 03 Javascript
用js判断输入是否为中文的函数
Mar 10 Javascript
jQuery中的$.ajax()方法应用
May 06 Javascript
jQuery中removeData()方法用法实例
Dec 27 Javascript
jQuery应用之jQuery链用法实例
Jan 19 Javascript
js面向对象之公有、私有、静态属性和方法详解
Apr 17 Javascript
jQuery控制DIV层实现由大到小,由远及近动画变化效果
Oct 09 Javascript
JavaScript中的this到底是什么(一)
Dec 09 Javascript
BootStrap扔进Django里的方法详解
May 13 Javascript
vue-router的钩子函数用法实例分析
Oct 26 Javascript
jQuery HTML css()方法与css类实例详解
May 20 jQuery
微信小程序 聊天室简单实现
Apr 19 #Javascript
Vuex之理解Store的用法
Apr 19 #Javascript
微信小程序 判断手机号的实现代码
Apr 19 #Javascript
Vuex简单入门
Apr 19 #Javascript
微信小程序 滚动到某个位置添加class效果实现代码
Apr 19 #Javascript
微信小程序 slider的简单实例
Apr 19 #Javascript
详解Node.js中exports和module.exports的区别
Apr 19 #Javascript
You might like
php 动态执行带有参数的类方法
2009/04/10 PHP
PHP第一季视频教程(李炎恢+php100 不断更新)
2011/05/29 PHP
php 启动报错如何解决
2014/01/17 PHP
php+Memcached实现简单留言板功能示例
2017/02/15 PHP
PHP判断一个数组是另一个数组子集的方法详解
2017/07/31 PHP
PHP页面静态化――纯静态与伪静态用法详解
2020/06/05 PHP
解析JavaScript中的标签语句
2013/06/19 Javascript
jQuery中mouseover事件用法实例
2014/12/26 Javascript
jQuery随手笔记之常用的jQuery操作DOM事件
2015/11/29 Javascript
基于javascript数组实现图片轮播
2016/05/02 Javascript
js判断某个字符出现的次数的简单实例
2016/06/03 Javascript
jQuery实现table中的tr上下移动并保持序号不变的实例代码
2016/07/11 Javascript
js 实现数值的千分位及保存小数方法(推荐)
2016/08/01 Javascript
HTML5基于Tomcat 7.0实现WebSocket连接并实现简单的实时聊天
2016/10/31 Javascript
详解jQuery uploadify文件上传插件的使用方法
2016/12/16 Javascript
微信小程序 数组中的push与concat的区别
2017/01/05 Javascript
详解vue-router和vue-cli以及组件之间的传值
2017/07/04 Javascript
详解ES6之async+await 同步/异步方案
2017/09/19 Javascript
基于vue hash模式微信分享#号的解决
2020/09/07 Javascript
[03:17]DOTA2英雄基础教程 剧毒术士
2013/12/12 DOTA
[03:56]还原FTP电影首映式 DOTA2群星拼出遗迹世界
2014/03/26 DOTA
python实现斐波那契递归函数的方法
2014/09/08 Python
跟老齐学Python之一个免费的实验室
2014/09/14 Python
python删除过期文件的方法
2015/05/29 Python
Python实现图片转字符画的示例
2017/08/22 Python
Django 实现图片上传和显示过程详解
2019/07/18 Python
详解python中的模块及包导入
2019/08/30 Python
双向RNN:bidirectional_dynamic_rnn()函数的使用详解
2020/01/20 Python
opencv 图像腐蚀和图像膨胀的实现
2020/07/07 Python
使用BeautifulSoup4解析XML的方法小结
2020/12/07 Python
美国排名第一的在线葡萄酒商店:Wine.com
2016/09/07 全球购物
党支部公开承诺践诺书
2014/03/28 职场文书
见习报告的格式
2014/11/04 职场文书
社区党务工作总结2015
2015/05/19 职场文书
如何理解Vue前后端数据交互与显示
2021/05/10 Vue.js
MySQL GTID复制的具体使用
2022/05/20 MySQL