合并reducer

news2024/12/25 13:21:17

reducer工程化第一步:合并

各个模块下reducer的模板:
在这里插入图片描述
1.@符是代表直接从src下面进行寻找
2.定义初始状态
3.深拷贝状态
4.进行行为判断

votereducer这么写?在这里插入图片描述

合并reducer

在这里插入图片描述

导出总的reducer

在这里插入图片描述

模块化开发后往事件池放的更新方法,在disptch的时候,每次都要把事件池里面的所有事件都执行一遍,可不可以优化事件池里面的更新方法只需要执行指定的更新方法吗??

可以通过在事件池中维护一个注册表来优化事件的触发。具体而言,我们可以在注册表中存储事件名与对应的回调函数之间的映射关系,并在触发事件时只执行对应的回调函数。

下面是一种实现方法的示例代码:

// 注册表,存储事件名与回调函数的映射
const listeners = {};

// 注册事件监听器
function addListener(eventName, callback) {
  if (!listeners[eventName]) {
    listeners[eventName] = [];
  }
  listeners[eventName].push(callback);
}

// 触发事件,只执行注册表中对应的回调函数
function dispatch(eventName, payload) {
  const callbacks = listeners[eventName] || [];
  callbacks.forEach(callback => callback(payload));
}

对于应用中的每个事件,我们可以通过addListener方法将其注册到事件池中,例如:

addListener('updateUser', (payload) => {
  console.log('updated user:', payload);
});

这样,在调用dispatch方法时,只会执行updateUser事件对应的回调函数而不是全部事件的回调函数。例如:

dispatch('updateUser', { name: 'Alice', age: 30 });
// 输出:updated user: { name: 'Alice', age: 30 }

这样的优化可以有效减少不必要的回调函数执行,提高应用性能。

这种优化需要对原有的事件触发机制进行修改,因此需要修改源码。实现起来也比较容易,只需要在dispatch方法中增加一个注册表,将事件名和回调函数一一对应起来,而不是在触发事件时遍历所有事件的回调函数。

当然,Redux 源码中已经有现成的实现,该实现叫做 reduce-reducers,它提供了一个 enhanceReducer 函数,可以将多个 Reducer 函数合并成单个 Reducer。在应用程序的状态更新时,只有与当前 Action 相关的 Reducer 函数才会得到调用,这样可以避免无意义的更新操作,提高性能。

如果你使用 Redux,可以考虑使用 reduce-reducers 或者 Redux Toolkit 提供的 createSlice 函数来实现这一优化。


第二步:每一次dispatch派发的时候,都会去每个模块的reducer中找一遍,把所有和派发行为标识匹配的逻辑执行!!

可能存在的问题:团队协作开发的时候,因为开发的人多,最后很可能派发的行为标识会有冲突!!

所以我们一定要保证,不管哪个模块,哪个组件,我们派发的行为标识,必须是唯一的!!基于“宏管理(统一管理)”,让所有派发的行为标识,唯一性!!!

在这里插入图片描述

reducer中怎么修改:

在这里插入图片描述


第三步:actionCreator的创建:把派发的对象进行模块管理:

在这里插入图片描述

再把action合并成一个action:

在这里插入图片描述

修改reducers中:

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

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

相关文章

交换机新设备版本升级(超详细!快进来学习!)

本文主要讲述了华三新上架交换机机设备升级全过程!同理,其他的交换机设备进行升级也是同样的思路! 升级流程 1、使用console线以及网线将电脑和交换机进行连接(console口和网口); 2、打开以太网卡,“控制面…

25k字图文解读YOLOv8及实例分割(附python代码)

学习使用 未经详细专业审核 目录 0.引言1.概述1.1 Backbone1.2 Head1.3 Loss1.4 Train 2.模型结构2.1 Backbone和Neck的具体变化2.2 Head的具体变化 3.Loss计算3.1 正负样本分配策略3.2 Loss计算 4.训练数据增强5.训练策略6.模型推理过程7.网络模型解析7.1 卷积神经单元&#x…

软件设计模式之原型模式

一.定义 原型模式(Prototype Pattern)的简单程度仅次于单例模式和迭代器模式。正是由于简单,使用的场景才非常地多,其定义如下: Specify the kinds of objects to create using a prototypical instance, and create new objects by copyingthis protot…

基础设施SIG月度动态:ABS新增ISO、VHD镜像构建,自动热补丁制作流程正式上线

基础设施 SIG(OpenAnolis Infra SIG)目标:负责 OpenAnolis 社区基础设施工程平台的建设,包括官网、Bugzilla、Maillist、ABS、ANAS、CI 门禁以及社区 DevOps 相关的研发工程系统。 01 SIG 整体进展 1、龙蜥社区官网与 CSDN dev…

smigroup LAFERT 伺服电机 B7108P-03177

​ smigroup LAFERT 伺服电机 B7108P-03177 smigroup LAFERT 伺服电机 B7108P-03177 从系统的可扩展性和兼容性的方面来说: 市场上控制类产品繁多,无论DCS还是PLC,均有很多厂商在生产和销售。对于PLC系统来说,一般没有或很少有扩…

如何与领导团队沟通并赢得他们的支持以推动企业的敏捷转型进程?

在与领导团队沟通并赢得他们对敏捷转型的支持时,重要的是要从战略上有效地处理这种情况。建议采取的一些步骤: 了解他们的观点:在开始任何沟通之前,尝试了解领导团队对敏捷转型的担忧和保留意见。可以帮助调整方法并解决具体问题。…

2023年5月信息系统项目管理师试题及答案解析

请点击↑关注、收藏,本博客免费为你获取精彩知识分享!有惊喜哟!! 1.“新型基础设施”主要包括信息技术设施,融合基础设施和创新基础设施三个方面,其中信息基础设施包括___1___。 ①通信基础设施 ②智能交…

【Mysql 存储过程 Or 存储函数 傻傻分不清? 】

MySQL的存储函数(自定义函数)和存储过程都是用于存储SQL语句的。但是什么时候用什么呢?是不是总是傻傻的分不清? 本文来详细的讲一下存储函数 和存储过程 ,以后再也不会迷糊。 存储函数 | 存储过程 一、 异同点二、 存…

云原生之深入解析Kubernetes中Kubectl Top如何进行资源监控

一、Kubectl top 的使用 kubectl top 是基础命令,但是需要部署配套的组件才能获取到监控值: 1.8 以下:部署 heapter; 1.8 以上:部署 metric-server; kubectl top node:查看 node 的使用情况&a…

25.单元测试、反射

一.单元测试 1.1 什么是单元测试 单元测试就是针对最小的功能单元编写测试代码,Java程序最小的功能单元是方法。因此,单元测试就是针对Java方法进行的测试,进而检查 方法的正确性。 1.2 目前测试方法是怎么进行的 ①只有一个main方法&#x…

可观测性最佳实践 | 警惕!未知的风险正在摧毁你的系统

无声的刺客最为致命,往往表面看似云淡风轻,实际早已危机重重,血雨腥风一触即发。这样的场面看似离我们很遥远,但每个开发运维人员实际都遇到过。 在全球数字经济大潮下,现代企业纷纷投身于业务数字化转型的浪潮。越来越…

java8 (jdk 1.8) 新特性—— 方法引用+构造器引用

1. 方法引用 方法引用 其实 本质上 就是Lambda 表达式 ,之前已经知道 Lambda 是作为一个函数式接口的实例 ,因此,方法引用也就是一个函数式接口的实例 使用的情况: 当要将值传给Lambda 体,已经有实现的方法&#xff…

【Python 随练】判断101到200的素数

题目: 判断 101-200 之间有多少个素数,并输出所有素数。 简介: 在本篇博客中,我们将解决一个常见的问题:判断101到200之间的素数,并输出所有素数的列表。我们将给出问题的解析,并提供一个完整…

2023年了要怎么理解原型和原型链

1.prototype和__proto__有什么不可告人的关系? 说道原型对象,那一定绕不开几个概念: prototype,__proto__,constructor。 首先解释一下prototype是什么,原型对象。V8引擎给所有函数内置的一个对象。也就是只要创建的…

瑞丽-伯纳德对流的拉格朗日拟序结构(FTLE场结果对比)

FTLE场,即有限李雅普诺夫指数场是识别拉格朗日拟序结构的一种方法,其主要思路是如下: 1、t时刻在场内均匀布置粒子 2、计算t–>tT时刻后粒子的位置,这里粒子任意时刻的速度有速度场插值得到 3、根据两个时刻的粒子位置计算得…

资讯 |智汇云舟受邀出席WGDC大会并获“年度最具创新力企业“奖项

5月17日,由泰伯网主办的第十二届WGDC2023全球地理信息开发者大会在北京隆重召开。开幕式上重磅发布了“2023年度最具创新力”榜单,智汇云舟凭借技术创新研发与应用方面取得的诸多突破,获数字孪生赛道“年度最具创新力企业"奖项。公司产品…

Django高级扩展之Paginator分页实现

在项目中很常见的一种功能,主要用于大量数据在一页显示过于冗长,分为一页显示多条数据,分隔为多页显示;并常与条件筛选结合使用。 目录 Paginator对象 创建对象 属性 方法 异常 Page对象 创建对象 属性 方法 Paginator与…

华为OD机试之阿里巴巴找黄金宝箱(I)

阿里巴巴找黄金宝箱(I) 题目描述 一贫如洗的樵夫阿里巴巴在去砍柴的路上,无意中发现了强盗集团的藏宝地,藏宝地有编号从0~N的箱子,每个箱子上面贴有一个数字,箱子中可能有一个黄金宝箱。 黄金宝箱满足排在它之前的所有箱子数字…

Kubernetes Pod 生命周期

Pod 生命周期是其从创建开始至终止退出的事件范围。 Pod 状态 Pending API server 创建了 Pod 对象并已存入 etcd 中,但尚未调度完成或仍处于从镜像仓库下载镜像的过程中。Running Pod 已经被调度至某节点,并且所有容器都已经被 kubelet 创建完成。Suc…

spss分析方法-聚类分析

聚类分析是根据研究对象的特征,按照一定标准对研究对象进行分类的一种分析方法。下面我们主要从下面四个方面来解说: 实际应用理论思想建立模型 分析结果 一、实际应用 聚类分析的目标就是在相似的基础上收集数据来分类。 聚类源于很多领域&#xf…