Vuex 十分简单好用,没用过难免会有神秘感,以致于往往就高估了其使用难度,其实也就那么回事,没什么高大上的。

Vuex 是什么

Vuex 是专门为 Vue.js 设计的状态管理库,它采用集中式存储管理应用的所有组件的状态。

状态管理是什么

状态管理并不是什么神奇的概念,其实你一直都在做,即便你从来没了解过状态管理的概念。

我们先看文档里的示例,一个 Vue 计数应用:

new Vue({// statedata() {return {count: 0};},// viewtemplate: `<div>{{ count }}</div>`,// actionsmethods: {increment() {this.count++;}}
});
复制代码

这个应用包含以下几个部分:

  • state,驱动应用的数据源;
  • view,以声明方式将 state 映射到视图;
  • actions,响应在 view 上的用户输入导致的状态变化。

这是一个状态自管理应用,状态自管理?可以这样理解,state,view,action,三部分都写在了组件内,状态由应用组件各自管理,即自己的状态自己管理

而我们常说的状态管理,往往是指外部管理,目的是对状态和组件进行分离,具体到 Vuex 里的表现就是:把应用的所有组件的状态抽取出来,以一个全局单例模式在应用外部采用集中式存储管理

看来,状态管理并不是新鲜的东西,不过就是把内部对 state 部分的操作,都拿到外部去罢了,事实也确实如此。

为什么需要状态管理

很多人最初喜欢用 Vue,React 这类框架,大概都是因为框架的响应式特性——当数据改变时,视图会进行重新渲染。这其实正是框架解决的最核心的问题。

1. view 显示了 state
2. 用户在 view 上操作,会触发 action 去改变 state
3. state 的改变,导致 view 层再渲染

有没有发现一个有趣的问题,在这个单向流动的过程中,

  • 步骤 1 和 步骤 3 已经由 Vue 的响应式特性来做了,我们并不关心其实现细节。
  • 步骤 2 是我们参与的地方,这正是状态管理的部分。

既然我们并不关心 view 层是如何自动渲染的,为什么我们不把状态管理view 层的代码分离开,分开的好处显而易见,比如我们可以随时换掉 view 层的实现,而不用修改状态管理部分的任何代码,这个理由足够让我们单独对状态进行管理。

为什么需要 Vuex

对于简单的状态管理,一个简单的 store 模式就足够了,官方示例:

var store = {debug: true,state: {message: "Hello!"},setMessageAction(newValue) {if (this.debug) console.log("setMessageAction triggered with", newValue);this.state.message = newValue;},clearMessageAction() {if (this.debug) console.log("clearMessageAction triggered");this.state.message = "";}
};var vmA = new Vue({data: {privateState: {},sharedState: store.state}
});var vmB = new Vue({data: {privateState: {},sharedState: store.state}
});
复制代码
  • 所有 store 中 state 的改变,都放置在 store 自身的 action 中去管理。这种集中式状态管理能够被更容易地理解哪种类型的 mutation 将会发生,以及它们是如何被触发。当错误出现时,我们现在也会有一个 log 记录 bug 之前发生了什么。
  • 此外,每个实例/组件仍然可以拥有和管理自己的私有状态:

接着我们继续延伸约定,

  • 组件不允许直接修改属于 store 实例的 state,而应执行 action 来分发 (dispatch) 事件通知 store 去改变

这其实已经是 Flux 架构,这样约定的好处是,我们能够记录所有 store 中发生的 state 改变,同时实现能做到记录变更 (mutation)、保存状态快照、历史回滚/时光旅行的先进的调试工具。

Vuex 正是借鉴了 Flux、Redux 等,为了更好地在组件外部管理状态,显然我们需要 Vuex。

Flux 架构就像眼镜

Flux 架构就像眼镜:您自会知道什么时候需要它。

近视了就需要戴眼镜了,近视 100 度你可能不需要,200 度你可能也不需要,不要着急,总有一个度数会让你带上它。

本文对 Vuex 官方文档重新组织编排,尝试更好的理解状态管理。

【前端笔记】Vuex 是什么,为什么需要相关推荐

  1. Vuex 4源码学习笔记 - Vuex是怎么与Vue结合?(三)

    在上一篇笔记中:Vuex源码学习笔记 - Vuex开发运行流程(二) 我们通过运行npm run dev命令来启动webpack,来开发Vuex,并在Vuex的createStore函数中添加了第一个 ...

  2. 移动端前端笔记 — 遇到的常见JS与CSS问题及解决方法

    移动端前端笔记 - 遇到的常见JS与CSS问题及解决方法 参考文章: (1)移动端前端笔记 - 遇到的常见JS与CSS问题及解决方法 (2)https://www.cnblogs.com/zhaoda ...

  3. Web前端 笔记 (21-45)

    Web前端 笔记 (21-45) 21.嵌套列表 1.概念 2.有(无)序列表嵌套 3.定义列表嵌套 22.表格标签 1.种类 2.举例 未加语义化标签 添加语义化标签 23.表格属性 1.常见表格属 ...

  4. Henry前端笔记之 Node及npm相关

    Henry前端笔记之 npm入门相关 NodeJs 简介: 1.Nod简介与概述: 2.交互式运行环境:PEPL 3.Node.js模块和包 3.npm包管理工具 npm简介详见:https://dk ...

  5. 1.前端笔记之html

    title: 1.前端笔记之HTML date: 2016-04-04 23:21:52 tags: Python categories: Python --- 作者:刘耀 出处:http://www ...

  6. [前端笔记——HTML介绍] 4.HTML文本基础+超链接+高级文本格式

    [前端笔记--HTML介绍] 4.HTML文本基础+超链接+高级文本格式 1.HTML文本基础 1.1标题和段落 1.2列表 1.2.1无序列表(unordered) 1.2.2有序列表(ordere ...

  7. [前端笔记——HTML 表格] 8.HTML 表格

    [前端笔记--HTML 表格] 8.HTML 表格 1.HTML 表格基础 1.1 什么是表格? 1.2 创建表格: 2.HTML 表格高级特性和无障碍 2.1 使用`<caption>` ...

  8. Henry前端笔记之 Date对象详解

    Henry前端笔记之 Date对象详解 Date 对象 1 时间格式简介 2 Date.now 与 new Date().getTime() 的区别 3 Date对象详解 普通函数的用法 构造函数的用 ...

  9. Henry前端笔记之 git实际操作问题记录

    Henry前端笔记之 git实际操作问题记录 在拉取后发现之前有未推送的更改 早上有一次提交没有推送成功 后来强制拉取覆盖了 因为冲突太多~~ 现在决定找回之前的提交 错误分析: 解决方案: 参考文献 ...

  10. Henry前端笔记之 函数封装

    Henry前端笔记 (三)函数封装 基本函数 1 在Javascript中什么是伪(类)数组?如何将伪数组转化为标准数组? 时间戳转为日期格式 基本函数 1 在Javascript中什么是伪(类)数组 ...

最新文章

  1. Dynamic Network Surgery for Efficient DNNs
  2. 公办低分二本_三本4所二本3所,四川考生都是用这7所大学保底的,分数低保录取...
  3. python读取、写入、移动、复制文件(夹)以及其他关于文件(夹)的操作
  4. httpclient通过POST来上传文件,而不是通过流的形式,并在服务端进行解析(通过htt......
  5. mabatisplus怎么给实体类自定义属性_吊打面试官之:当实体类中的属性名和表中的字段名不一样 ,怎么办 ?...
  6. springMVC(一) --前端控制器(DispatcherServlet)的作用
  7. 洛谷 | P1010 幂次方
  8. Dart基础-运算符
  9. Ajax-ajax实例2-根据邮政编码获取地区信息
  10. 压缩word的简单方法看这里
  11. 用计算机怎么刷试听量,QQ音乐怎么刷播放次数,快速增加播放量
  12. python实战项目词云生成器(wordcloud+jieba+pyinstaller打包)——词云生成软件【Pyinstaller打包问题解决】
  13. 2021年危险化学品经营单位主要负责人报名考试及危险化学品经营单位主要负责人新版试题
  14. 微型计算机简单并行接口实验心得,实验二 简单并行接口
  15. 20210518第一天
  16. 关于自己制作的软件被杀毒软件误报的解决办法
  17. weblogic10.3.6补丁升级
  18. 计算机二级web程序设计考试环境,2018年计算机二级web程序设计考试大纲
  19. 唠唠python的协程 分享
  20. 基于工业物联网的工业机器人PHM架构

热门文章

  1. AI 热潮之下,初创企业能否躲过科技巨头的碾压?
  2. 壕!甲骨文创始人 8000 万美元买豪宅后打算拆掉
  3. HDU-1394-Minimum Inversion Number
  4. JSONP的实现原理
  5. ElasticSearch基础知识整理
  6. xml笔记整理_基础概括
  7. 安卓kernel自主唤醒系统方法—设置alarm
  8. webstorm更改scss输出路径
  9. 海量数据处理相关面试问题
  10. 【js】callback时代的变更