发布时间:2023-04-27 文章分类:WEB开发, 电脑百科 投稿人:赵颖 字号: 默认 | | 超大 打印

文章目录

    • Redux的核心理念介绍
      • Redux的出现背景
      • Redux核心理念-Store
      • Redux核心理念-action
      • Redux核心理念-reducer

Redux的核心理念介绍

此篇文章是React中的Redux状态管理库的基本介绍, Redux的详细使用过程在下篇文章中进行讲解

Redux的出现背景

JavaScript开发的应用程序,已经变得越来越复杂了:

JavaScript需要管理的状态越来越多,越来越复杂;

这些状态包括服务器返回的数据、缓存数据、用户操作产生的数据等等,也包括一些UI的状态,比如某些元素是否被选中,是否显示加载动效,当前分页;

管理不断变化的state是非常困难的:

状态之间相互会存在依赖,一个状态的变化会引起另一个状态的变化,View页面也有可能会引起状态的变化;

当应用程序复杂时,state在什么时候,因为什么原因而发生了变化,发生了怎么样的变化,会变得非常难以控制和追踪;

React是在视图层帮助我们解决了DOM的渲染过程,但是State依然是留给我们自己来管理:

无论是组件定义自己的state,还是组件之间的通信通过props进行传递; 也包括通过Context进行数据之间的共享;

React主要负责帮助我们管理视图,state如何维护最终还是我们自己来决定;

Redux就是一个帮助我们管理State的容器:Redux是JavaScript的状态容器,提供了可预测的状态管理;
Redux除了和React一起使用之外,它也可以和其他界面库一起来使用(比如Vue),并且它非常小(包括依赖在内,只有2kb)

Redux核心理念-Store

Redux的核心理念非常简单

比如我们有一个朋友列表需要共享到多个页面进行管理:

如果我们没有定义统一的规范来操作这段数据,那么整个数据的变化就是无法跟踪的;

比如页面的某处通过friends.push的方式增加了一条数据;

比如另一个页面通过friends[0].age = 25修改了一条数据;

friends: [
  {name: "aaa", age: 19},
  {name: "bbb", age: 20},
  {name: "ccc", age: 19},
  {name: "ddd", age: 18},
]

整个应用程序错综复杂,当出现bug时,很难跟踪到底哪里发生的变化;

因此我们可以定义一些数据, 将数据存放在store中供其他页面使用

Redux核心理念-action

Redux要求我们通过action来更新数据:

所有数据的变化,必须通过派发(dispatch)action来更新;

action是一个普通的JavaScript对象,用来描述这次更新的type和content;

强制使用action的好处是可以清晰的知道数据到底发生了什么样的变化,所有的数据变化都是可跟追、可预测的;

当然,目前我们的action是固定的对象;

真实应用中,我们会通过函数来定义,返回一个action;

Redux核心理念-reducer

但是如何将state和action联系在一起呢? 答案就是通过reducer

reducer是一个纯函数;

reducer做的事情就是将传入的state和action结合起来生成一个新的state;