Vuex 是什么?

官方是这么说的:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。

不懂?呵呵,没关系。我是这么认为的:Vuex 就是前端为了方便数据的操作而建立的一个” 前端数据库“。且听下文分解。。。

模块间是不共享作用域的,那么B 模块想要拿到 A 模块的数据,我们会怎么做?不要去想什么”状态管理“、”vuex“、”redux“、”函数式编程“什么的。。。

我们会定义一个全局变量,叫 aaa 吧,就是 window.aaa。然后把A 模块要共享的数据作为属性挂到 B 模块上。这样我们在 B 模块中通过 window.aaa 就可以拿到这个数据了。

但是问题来了,B 模块拿到了共享的数据,就叫他 xxx 吧?得了,名字太混乱了,咱先给它们都改下名字。那个全局变量既然是存东西的,就叫 store 吧,共享的数据就叫 state 吧,你叫他 data 也一样,反正我是叫它 state 了。

继续说我们的问题,问题是什么呢?B 模块拿到了 A 模块的数据 state,但是这个数据不是一成不变的呀,A 要操作这个数据的。那么我们是不是要在这个数据——state 改变的时候通知一下 B?那写个自定义事件吧。。。

好吧,你自己已经实现了一个迷你版的 vuex,其实 vuex 就帮你做了这点事儿。我们来看下它里面都有什么玩意儿。

这就是一个典型的 使用vuex生成的仓库。不懂?呵呵,没关系,也没打算说它。我们聊点别的。

后端是干什么的?进行数据库操作,处理请求,根据请求分发响应。我们就聊聊数据库的操作,不说 API。首先,你得能取吧?那么得有一套取数据的 API,我们给他们集中起个名字吧?既然是获取,那就叫getter 吧。我们还得存数据呀,是吧。存数据就是对数据库的修改,这些 API,我们也得给它起个名字,就叫 mutation,就这么定了。

OK,vuex 生成的仓库也就这么出来了,所以我说 vuex 就是” 前端的数据库“。State 就是数据库。Mutations 就是我们把数据存入数据库的 API,用来修改 state 的。getters 是我们从数据库里取数据的 API,既然是取,那么你肯定不能把数据库给改了吧?所以 getters 得是一个”纯函数“,就是不会对原数据造成影响的函数,比如 数组的concat()方法、slice()方法;与之对应的是数组的 push()方法、splice()方法,他们会改变原数组的值。然后我们把这几部分用 store 包一下,” vuex “就捣置出来了,用数据了就从 state 中取,改数据了记得 mutation 到 state 中。

哎,还漏了个 actions 呢。你想呀,后端从前端拿到了数据,总要做个处理吧,处理完了再存到数据库中。其实这就是 action的过程。当然你也可以不做处理,直接丢到数据库,所以vuex也可以在 action 中直接存,就是直接mutation。

现在,我们再来看看 vuex 的数据流。后(qian)端通过 action处理数据,然后通过 mutation 把处理后的数据放入数据库(state)中,谁要用就通过 getter从数据库(state)中取。

你都理解了?好吧,有卵用,还得回归到 API 上。

1、getters

// 获取控制变量 ctrl
export function getShowPage (state) {return state.ctrl.showPage
}

getters 是一个纯函数,接收参数 state,返回你想取的值,都不需要贴数据结构,很清晰吧。

// 获取store各项信息
export function getMeta (state) {return state.meta
}

这张图上,我们返回的是一个被变量控制的值,还可以先对获得的数据进行处理,然后再返回出去。

2、mutations

// 公共控制变量 ctrl[SHOW_PAGE] (state) {state.ctrl.showPage = true},

一个最简单的 mutation,就是把 state.ctrl.showData 的值改成 true,好吧,我觉得我是在说废话。Mutation除了接收 state 作为第一个参数外,还可以接收其他的参数,比如:

  [NEW_DATA] (state, payload, id){const newData = {id, data: payload}state.meta = Object.assign({}, {currentData: id})state.datas = Object.assign({}, newData)},

不用说了吧。。。

3、store与state

state就是根据你项目的需求,自己定义一个数据结构。Store中至少要注入两项,state 和 mutation。

const state = {currentPage: 1,user: '0121213',change: 0,page,ctrl,meta,configs,datas
}export default new Vuex.Store({state,mutations,
})

这是我定义的 state 和 store 的注入。

4、action

先来一个简单点的。

export const updateName = function({ dispatch, state }, name) {const payload = {name}dispatch('UPDATE_PAGE', payload)
}

一个叫 updateName 的 action(数据的中间处理),前面花括号是一个参数,state,如果不理解,看看阮一峰的 ES6入门,对象解构。它接收用户输入的数据 name,然后中间处理的过程就是把 name 包成了对象{name: name},然后通过 mutation(update_page) 存储。至于 update_page 干了什么,那不是 action(中间处理)的事儿,那是 mutation(存储)的逻辑。

export const updateData = function({ dispatch, state }, data) {const payload = dataconst id = state.meta.currentDataif (id === 'initial') {const id = createDataId()dispatch('NEW_DATA', payload, id)} else {dispatch('UPDATE_DATA', payload)}
}

这个 action 叫 updateData,里面先把 data 改了个名字,然后加了判断,如果 id 是‘initial’ 就怎么存。。。否则怎么存。。。

再来一个:

这个 action 很长,被我收起来了,我们看看它都做了什么。接收一个参数 payload,判断如果 id 是 initial,就生成 id,然后怎么存。。。如果 id 不是 initial,就怎么存。。。好像都一个套路。接着看,定义空的” privateConfig“、”initialData“,switch 块里面就是生成 privateConfig、initialData的地方。然后判断如果 cfid 是 initial,就生成 id,然后怎么存。。。如果 cfid 不是 initial,就怎么存。。。好吧,全是套路。

通过这几个小例子,我希望大家可以看到的是,各个类型的 API各司其职,mutation 只管存,你给我(dispatch)我就存;action只管中间处理,处理完我就给你,你怎么存我不管;Getter 我只管取,我不改的。

咱们再来看一个听着玄乎其神的异步操作的 action。

export const save = function({ dispatch, state }) {const params = stateapi.save(params).then(function(res) {console.log(res)dispatch('SAVE_SUCCESS', res)}).catch((err) => {console.log(err)dispatch('SAVE_FAIL', err)})
}

一个叫 save 的 action。首先在里面发起了一个请求,这个请求是经过包装的(改了名字叫 api.save),咱不管它改名字这茬儿。第一个 then 就是成功的回调,通过 res 拿到数据,拿到数据了就怎么存。。。第二个 catch 就是失败的回调,通过 err 拿到错误信息,拿到错误信息了怎么存。。。呵呵,跟if判断差不多嘛。。。其实异步的 action 还可以发送第三个 dispatch 的,在发起请求前先保存下原始数据,有时候有需求会用到的,比如官方 DEMO 的购物车。

看来形式怎么变,action 里面的逻辑不会变,它做的事情不会变。

5、它们是什么?

至于 mutation_type,mudules。。。这些都不是重点,可用可不用。Vuex 最强大的地方还在于它的伸缩性。你项目大了,需要分 mudules,项目小了一样可以用呀,甚至只需要建立一个 store.js,你有什么理由不用它?

理解了 getter,mutation,action了,但是也许你还不知道该怎么去用,因为你还不知道他们是什么东西。

截的官网的图,重点不是 mapGetters,重点是mapGetters写在了哪儿。写在了 computed 里面,这说明虽然 getter我们写的是函数,但是我们应该把它当成计算属性来用。再来看 action。

action放在了 methods 里面,说明我们应该把它当成函数来用。你以前写的 onclick = ‘函数’,现在就可以 onclick = ‘action’。我们在 vue 里面是这样写的,@click = “action()”,加不加括号看心情。

最后来看看 mutation。

它是在 store 里面写的,这说明,它就是个半成品,中间量,我们不应该在外面去操作它。

Vuex 什么时候用?

如果你问了这个问题,说明你不该用。但这个问题可以很容易并且很正确的回答。

等你痛了的时候,你就该用了。如果你连自己的代码都看不懂的时候,如果你自己都搞不清楚值在组件中是怎么传递的时候,如果你自己代码写了一半,恶心的想要撂挑子不干的时候,赶紧的,Vue.use(Vuex)!

Vuex从入门到入门相关推荐

  1. Android自动化测试-从入门到入门(5)AdapterView的测试

    在之前的文章中,我们简单介绍了Espresso的使用.通过onView()方法我们可以快速定位到界面上我们需要测试的目标元素.整体来说,onView()比较适用于UI比较简单的情况,在不需要过于复杂的 ...

  2. Android视频录制从不入门到入门系列教程(一)————简介

    一.WHY Android SDK提供了MediaRecorder帮助开发者进行视频的录制,不过这个类很鸡肋,实际项目中应该很少用到它,最大的原因我觉得莫过于其输出的视频分辨率太有限了,满足不了项目的 ...

  3. 【新手上路】语法入门算法入门题单

    作者:王清楚 链接:[新手上路]语法入门&算法入门题单_ACM竞赛_ACM/CSP/ICPC/CCPC/比赛经验/题解/资讯_牛客竞赛OJ_牛客网 来源:牛客网 介绍:本题单分为语法入门和算法 ...

  4. 数论基础,从入门到入门

    数论基础,从入门到入门 文章目录 数论基础,从入门到入门 一.常用算法 1.素数筛法 2.线性筛 3.快速幂 4.矩阵快速幂 5.辗转相除法/欧几里得算法 6.扩展欧几里得 7.中国剩余定理/CRT ...

  5. ActiveMQ入门-amq入门

    ActiveMQ是什么 ActiveMQ是Apache出品,最流行的,能力强劲的开源消息总线. ActiveMQ是一个完全支持JMS1.1和J2EE1.4规范的JMS Provider实现,尽管JMS ...

  6. BIOS从快速入门到入门1------浅谈BIOS

    眨眼间,从一个刚毕业的萌新小白,到现在的BIOS工程师,做了快2年半的x86服务器BIOS,勉强可以算是入门了.踩了很多坑,加了N多班,其中的辛酸和快乐,可能只有自己知道. 先不谈BIOS,我就个人经 ...

  7. GLOG从入门到入门

    GLOG从入门到入门 1 C++日志需求 任何可用的工程代码,都无法保证不出bug.因此,日志系统对于工程代码非常重要.对于像耳东小白这样的初级程序员(感谢某高级程序员大佬赐予"初级程序员& ...

  8. vuex状态管理简单入门

    1.安装vuex npm i --save-dev vuex 复制代码 2.为了方便管理,在src目录下新建文件夹store 新建index.js进行初始化 新建state.js进行数据存储 新建mu ...

  9. eselasticsearch入门_ElasticSearch入门 附.Net Core例子

    原标题:ElasticSearch入门 附.Net Core例子 1.什么是ElasticSearch? Elasticsearch是基于Lucene的搜索引擎.它提供了一个分布式,支持多租户的全文搜 ...

最新文章

  1. 剑指offer:面试题31. 栈的压入、弹出序列
  2. 关于JavaScript(脚本语言)
  3. Ubuntu常用基础命令
  4. java反射的编译过程_Java反射机制小结和实际操作
  5. 3D建模如何学习,小白6个月入门工作?3D建模要学多久才能接外包私活?
  6. idea中使用git只add部分module的更新
  7. SSM之SpringMVC框架
  8. 第一篇:webservice初探
  9. android开发,assets下面的资源文件不会变化/改动
  10. NSString去掉火车和空格
  11. Bootstarp daterangepicker 日期控件
  12. MAC下载安装JDK
  13. v强制打开usb调试平台_一加OnePlus 8T手机怎么打开手机开发者选项,开启USB调试连接电脑...
  14. dos系统功能调用的屏幕显示字符是( )号调用_linux混杂设备驱动模型分析(字符设备驱动模型使用篇)...
  15. 远程控制客户端使用教程-multiDesk
  16. asdfasdfasdf
  17. Excel常用技巧—数字和文本转换,三种方法任你选!!
  18. 旧金山州立大学计算机,旧金山州立大学(San-Francisco-State-University)_彬彬教育...
  19. Linux②—概述与基本命令,springboot微信点餐系统百度云
  20. [pandas] DataFrame 取指定列为某些值的行

热门文章

  1. nb传输协议和服务器的连接,NB-iot网络架构介绍_NB-iot的数据传输方式
  2. 《近匠》BugTags,所见即所得的 App 缺陷发现及管理工具
  3. 【Realtek】RTL8198D Dual Image逻辑说明及切换方法
  4. Flask 学习-47.Flask-RESTX 自定义响应内容marshal_with
  5. x64内核HOOK技术之拦截
  6. C语言中float值的比较
  7. 现在就开始创业的五个理由
  8. PowerBuilder 窗口透明SetLayeredWindowAttributes详解
  9. 渠道归因(一)传统渠道归因
  10. 从 keynote 大神到语雀画图大神,她是怎么做的?