React学习笔记(三)——redux状态管理工具

news2024/11/15 17:19:18

1. Redux快速上手

1.1 什么是Redux?

Redux 是 React 最常用的 集中状态管理工具 ,类似于 Vue 中的 Pinia(Vuex), 可以独立于框架运行
作用:
  • 通过集中管理的方式管理应用的状态

1.2 Redux快速体验

不和任何框架绑定,不使用任何构建工具,使用纯Redux实现计数器

模版:

使用步骤:
① 定义一个 reducer 函数 (根据当前想要做的修改返回一个新的状态)
② 使用createStore方法传入 reducer函数 生成一个 store实例对象
③ 使用store实例的 subscribe方法 订阅数据的变化(数据一旦变化,可以得到通知)
④ 使用store实例的 dispatch方法提交action对象 触发数据变化(告诉reducer你想怎么改数据)
  • 也就是说 action 对象就是 { type: 'INCREMENT' }
⑤ 使用store实例的 getState方法 获取最新的状态数据更新到视图中

1.3 Redux管理数据流程梳理

为了职责清晰,数据流向明确,Redux把整个数据修改的流程分成了 三个核心概念 ,分别是: state、action 和 reducer
  • state - 一个对象 存放着我们管理的数据状态
  • action - 一个对象 用来描述你想怎么改数据
  • reducer - 一个函数 根据 action 的描述生成一个新的 state

1.4 Redux 原理

① action

  • 动作对象
  • 包括两个属性:
    • type:标识属性,值为字符串,唯一,必要属性
    • data:数据属性,值类型任意,可选属性
  • 例子: { 'type' : 'add', data: 1 }

② reducer

  • 用于初识化状态、加工状态
  • 加工时,根据就的 state 和 action,产生新的 state 的纯函数

③ store

  • 将state、action、reducer 联系在一起的对象
  • 如何得到此对象
    • import { createStore } from ‘redux’
    • import reducer from './reducers'
    • const store = createStore(reducer)

  • 此对象的功能

    • getState() :得到 state

    • dispatch(action):分发 action,触发 reducer 调用,产生新的 state

    • subscribe(listener):注册监听,当产生了新的 state 时,自动调用

2. Redux与React - 环境准备

2.1 配套工具

在 React 中使用 redux,官方要求安装俩个其他插件 - Redux Toolkit 和 react-redux
① Redux Toolkit(RTK)- 官方推荐编写Redux逻辑的方式,是一套工具的集合集, 简化书写方式
  • 简化 store 的配置方式
  • 内置 immer 支持可变式状态修改
  • 内置 thunk 更好的异步创建

② react-redux - 用来 链接 Redux 和 React组件 的中间件

2.2 配置基础环境

① 使用 CRA 快速创建 React 项目
  • npx create-react-app react-redux
② 安装配套工具
  • npm i @reduxjs/toolkit react-redux
③ 启动项目
  • npm run start

2.3 store目录结构设计

  • 通常集中状态管理的部分都会单独创建一个单独的 `store` 目录
  • 应用通常会有很多个子 store 模块,所以创建一个 `modules` 目录,在内部编写业务分类的子store(子仓库
  • store中的入口文件 index.js 的作用是组合modules中所有的子模块,并导出 store(总仓库

3. Redux与React - 实现counter

3.1 整体路径熟悉

3.2 使用React Toolkit 创建 counterStore

① counterStore.js 子仓库

  • counterStore.js 子仓库的创建

  • 导出子仓库中修改数据的 reducer(根据 action 的描述生成一个新的 state)和 action (type 用来描述如何修改数据)

② store/index.js 总仓库

  • 安装总仓库(configureStore
  • 创建总仓库
  • 导入子仓库的 reducer (根据 action 的描述,生成新的 state)
  • 在总仓库的 reducer 中组合 子仓库的 reducer
  • 导出总仓库

3.3 为React注入store

react-redux 负责把 Redux 和 React 链接 起来,内置 Provider 组件,通过 store 参数把创建好的store 实例(总仓库)注入到应用中,链接正式建立
  • index.js 项目如口文件

3.4 React组件使用store中的数据

在 React 组件中使用 store 中的数据,需要用到一个 钩子函数 - useSelector, 它的作用是把 store中的数据映射到组件中,在 App.js 根组件中的使用样例如下:
  • 通过 state.counter 拿到 counter 子模块

3.5 React组件修改store中的数据

React 组件中修改 store 中的数据需要借助另外一个 hook 函数 - useDispatch ,它的作用是生成提交 action 对象 的 dispatch 函数,使用样例如下:

3.6 总结

  • 组件中使用哪个hook函数获取store中的数据?
    • useSelector
  • 组件中使用哪个hook函数获取dispatch方法?
    • useDispatch
  • 如何得到要提交action对象?
    • 执行store模块中导出的actionCreater方法

4. Redux与React - 提交action传参

4.1 需求说明

组件中有俩个按钮 `add to 10` 和 `add to 20` 可以直接把 count 值修改到对应的数字,目 标count值是在组件中传递过去的,需要在 提交action的时候传递参数

4.2 提交action传参实现需求

在 reducers 的同步修改方法中 添加 action 对象参数 ,在 调用 actionCreater 的时候传递参数 ,参数会被传递到  action 对象 payload 属性

5. Redux与React - 异步状态操作

5.1 需求理解

5.2 异步操作样板代码

① 创建store的写法保持不变,配置好同步修改状态的方法
② 单独封装一个函数,在函数内部return一个新函数,在新函数中
  • 封装异步请求获取数据
  • 调用同步actionCreater传入异步数据生成一个action对象,并使用dispatch提交

③ 组件中dispatch的写法保持不变

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2071305.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【OpenGL学习笔记】--图像管线

图像管线(Image Pipeline)是计算机图形学中一个核心概念,尤其是在图形处理和渲染的上下文中。它是一个用于处理和渲染图像的流程,其中包括从场景数据的输入到最终图像输出的各个阶段。 图像管线的组成 顶点处理(Verte…

大模型入门到精通——使用Embedding API及搭建本地知识库(一)

使用Embedding API及搭建本地知识库 1. 基于智谱AI调用Embedding API实现词向量编码 首先,生成.env 文件,填写好智谱AI的API-key 参考:大模型入门到实战——基于智谱API key 调用大模型文本生成 读取本地/项目的环境变量。 find_dotenv(…

基于SSM的在线家教管理系统的设计与实现 (含源码+sql+视频导入教程+论文+PPT)

👉文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1 、功能描述 基于SSM的在线家教管理系统拥有三个角色 管理员:用户管理、教师管理、简历管理、申请管理、课程管理、招聘教师管理、应聘管理、评价管理等 教师:课程管理、应聘…

Prometheus Operator部署管理

Prometheus Operator部署管理 Prometheus Operator & Kube-Prometheus & Helm chart 部署区别 Prometheus Operator 是 Kubernetes 原生的工具,它通过将 Prometheus 资源定义为 Kubernetes 对象(CRD)来简化 Prometheus 集群的管理。…

如何使用ssm实现公司项目管理系统设计与实现

TOC ssm136公司项目管理系统设计与实现jsp 绪论 1.1 研究背景 当前社会各行业领域竞争压力非常大,随着当前时代的信息化,科学化发展,让社会各行业领域都争相使用新的信息技术,对行业内的各种相关数据进行科学化,规…

Avg函数求比率的应用(SQL)

题目 在 SQL 中,AVG 函数用于计算一组数值的平均值。这个功能也可以用来计算比率或比例。 平均值 可以用来计算比率的原因: 二元值:在许多情况下,我们用 1 和 0 表示发生或未发生的事件。例如,在你的查询中&#xff0…

基于Java的C语言课程教学实践小程序的设计与实现(论文+源码)_kaic

基于Java的C语言课程教学实践小程序的设计与实现 摘 要 在当前信息技术迅猛发展的大背景下,为了学生更好地利用信息技术学习C语言,急需开发一款C语言课程教学实践小程序。‎这个小程序可以让学生不再局限于课堂学习‎的教学模式,而是能够随…

freeCAD与stl文件如何互切?

大家好,我是山羊君Goat。 作为硬件工程师,如果需要给自己的硬件主板做一个DIY的造型,比如说B站稚晖君DIY的小电视等等。 对于这个,那3D打印技术就必不可少了(怪不得说硬件学的东西都很杂 )。 FreeCAD是一款…

BeautifulSoup4通过lxml使用Xpath定位实例

有以下html。<a>中含有图片链接&#xff08;可能有多个<a>&#xff0c;每一个都含有一张图片链接&#xff09;。最后一个<div>中含有文字。 上代码&#xff1a; import requests from bs4 import BeautifulSoup from lxml import etreeurlhttps://www.aaabb…

动态规划类型题目汇总及解析(持续更新)

目录 数字三角形模型 摘花生 最低通行费 方格取数&#xff08;洛谷&#xff09; 传纸条&#xff08;洛谷&#xff09; 最长上升子序列模型 最长上升子序列&#xff08;洛谷&#xff09;&最长递增子序列&#xff08;leetcode&#xff09; leetcode674. 最长连续递…

Image-to-Image Translation 图像翻译任务中的输入成对图像拼接成一张图技术详解

引 言 在图像翻译任务中&#xff0c;近几年比较火热的Generative Adversarial Nets (GAN)模型以及各种变体深受视觉研究团体的青睐&#xff0c;在具体任务中取得不错的实验表现。图像翻译包含两部分内容&#xff1a;一个是图像内容(image content)显示内部存在的实体,用于区分不…

【C++ Primer Plus习题】4.5

问题: 解答: #include <iostream> using namespace std;typedef struct _CandyBar {string brand;float weight;int calorie; }CandyBar;int main() {CandyBar snack { "德芙",2.1,20};cout << "品牌:" << snack.brand << endl;…

计算机毕业设计 养老院管理系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

&#x1f34a;作者&#xff1a;计算机编程-吉哥 &#x1f34a;简介&#xff1a;专业从事JavaWeb程序开发&#xff0c;微信小程序开发&#xff0c;定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事&#xff0c;生活就是快乐的。 &#x1f34a;心愿&#xff1a;点…

IO进程day01(函数接口fopen、fclose、fgetc、fputc、fgets、fputs)

目录 函数接口 1》打开文件fopen 2》关闭文件fclose 3》文件读写操作 1> 每次读写一个字符&#xff1a;fgetc(),fputc() 针对文件读写 针对终端读写 练习&#xff1a;实现 cat 命令功能 格式&#xff1a;cat 文件名 2> 每次一个字符串的读写 fgets() 和 fputs() …

数据集笔记: FourSquare - NYC and Tokyo Check-ins

FourSquare - NYC and Tokyo Check-ins (kaggle.com) 这个数据集包含了从2012年4月12日到2013年2月16日&#xff0c;约10个月时间内在纽约市和东京收集的签到数据。数据集中包含纽约市的227,428次签到和东京的573,703次签到。每个文件包括以下8个字段&#xff1a; 用户ID&…

Shell脚本学习_运算符

目录 一、算数运算符 1、expr命令&#xff1a; 2、算数运算符介绍&#xff1a; 3、使用 ( ( ) ) 进行运算&#xff1a; 4、bc命令&#xff1a; 1.bc中互动式的数学运算&#xff1a; 2.非互动式的管道运算&#xff1a; 3.非互动式的输入重定向运算&#xff1a; 二、比较运…

Kafka的基本概念

目录 1.Kafka的介绍 1.1介绍 1.2Kafka的概念 1.3.Kafka实现的日志聚合 1.4简单的收发消息 1.5其他消费模式 1.5.1指定消费进度 1.5.2分组消费 1.5.3查看消费者组的偏移量 1.6基于Zookeeper的Kafka集群 1.6.1使用集群的原因 1.6.2Kafka集群架构 1.6.3Topic下的Part…

2024年8月25日 十二生肖 今日运势

小运播报&#xff1a;2024年8月25日&#xff0c;星期日&#xff0c;农历七月廿二 &#xff08;甲辰年壬申月辛酉日&#xff09;&#xff0c;法定节假日。 红榜生肖&#xff1a;龙、牛、蛇 需要注意&#xff1a;鸡、狗、兔 喜神方位&#xff1a;西南方 财神方位&#xff1a;…

UVM中的TLM(事务级建模)通信(2)

上一篇介绍了UVM中利用TLM进行的一对一通信&#xff1a;UVM中的TLM(事务级建模)通信(1)-CSDN博客&#xff0c;除此之外&#xff0c;UVM还有两种特殊的端口&#xff1a;analysis_port和analysis_export&#xff0c;用于完成一对多的通信。 1.analysis端口 这两种端口同样也是用于…

域名泛解析是什么?如何设置?

在当今数字化的时代&#xff0c;网站建设和网络运营对于企业和个人来说都变得至关重要。而在这个过程中&#xff0c;域名的管理和配置起着关键作用。其中&#xff0c;域名泛解析是一个重要的概念&#xff0c;它可以为网站的运营和管理带来诸多便利。 一、域名泛解析是什么&…