当前位置: 首页 > news >正文

ts:数组的常用方法(reduce累加)

ts:数组的常用方法(reduce累加)

  • 一、主要内容说明
  • 二、例子
    • reduce方法(累加)
      • 1.源码1 (reduce方法)
      • 2.源码1运行效果
  • 三、结语
  • 四、定位日期

一、主要内容说明

ts中数组的reduce方法,用于数组元素的累加。reduce方法可设置的5个参数如下:

let arr:string[];
let new_arr=arr.reduce((A,B,C,D),E);A----累加值,保存上一次调用回调函数的返回值,或初始值B----当前正在处理的数组中的某个元素C----(可选)当前处理的数组元素的索引C----(可选)源数组E----(可选)初始值,可自行设置的初始值参数,若没有设置以数组中的第一个元素为初始值。

一般情况下我们只用到A和B这两个参数。使用箭头函数,输入A、B对象,对A、B对象进行函数逻辑变换,若求总和值,可如下设置:

let arr:string[];
let new_arr=arr.reduce((A,B)=>A+B,10);

A是不断累加的总和,B为当前运行排到的元素。上例我们设置的初始值为10,那么第一轮的总和数值为 (A1=10)+B1,这个值就会累加到A上。到了第二轮,那么就是A2=[(A1=10)+B1]+B2,以此类推A可以累加输出所有的数值。初始值为自己设置和数组元素类型相同的参数,也可不设置,而默认选用数组第一个元素的值。reduce方法和下边循环累加逻辑思想很相似。

let sum = 0;
for (i = 0; i < 10; i++) {sum = sum + i;}

二、例子

reduce方法(累加)

当数组中的元素为number一类,我们可以用reduce累加元素数值。若原数组为string字符串类型,用reduce累加,则会使原数组中的各个小字符串元素合并成为一个大的字符串。也可以使用对其他类型的对象函数中的某些值进行累加。

1.源码1 (reduce方法)

// 数字数组
// 数字数组
const numbers: number[] = [764, 765, 766, 767];// 使用 reduce 计算数组中所有数字的总和,未设置初始值
const sum_1 = numbers.reduce((A, B) => A + B);
console.log(sum_1); // 输出:3062// 使用 reduce 计算数组中所有数字的总和,并设置初始值为 1000000
const sum_2 = numbers.reduce((sum, num) => sum + num, 1000000);
console.log(sum_2); // 输出:1003062console.log(`\n分隔行------------------------------\n`);// 字符串数组
const str: string[] = ["元素1", "元素2", "元素3", "元素4", "元素5", "元素6"];// 使用 reduce 连接字符串,并设置初始值
const sum_3 = str.reduce((A, B) => A + "--" + B, "如果设置起始元素:");
console.log(sum_3); // 输出:如果设置起始元素:元素1--元素2--元素3--元素4--元素5--元素6
console.log("原数组:" + str);// 原数组console.log(`\n分隔行------------------------------\n`);// 定义 Message 接口
interface Message {name: string;num: number;
}// 消息数组
const mes: Message[] = [{ name: "桃子", num: 764 },{ name: "苹果", num: 765 },{ name: "猕猴桃", num: 766 },{ name: "西瓜", num: 767 }
];// 使用 reduce 计算水果数量总和,初始值为 0
const mes_2 = mes.reduce((sum, message) => sum + message.num, 0); // 从 0 开始累加数量// 输出结果
console.log("所有水果总和:" + mes_2); // 输出:所有水果总和:3062

2.源码1运行效果

在这里插入图片描述

三、结语

每日过一遍学过的内容,写下学过方面的知识,印象也会深些。其实不是很难的内容,但为啥完成一篇博文也会花费许多时间,搞不明白。
类class的简单创建已经简单过一遍,类里面的对象变量,可设置为公共、私有等的内容,还有继承和public静态类的设置。其实可选内容也挺多,但有时候也难以下手编写。总之,加油吧!
由于笔者的能力有限,创作的内容有所不足在所难免,也敬请读者包涵和指出,万分感谢!

四、定位日期

2024:10:28;
21:20;

相关文章:

ts:数组的常用方法(reduce累加)

ts&#xff1a;数组的常用方法&#xff08;reduce累加&#xff09; 一、主要内容说明二、例子reduce方法&#xff08;累加&#xff09;1.源码1 &#xff08;reduce方法&#xff09;2.源码1运行效果 三、结语四、定位日期 一、主要内容说明 ts中数组的reduce方法&#xff0c;用…...

Begin

cpp 编程的发展方向还是很多的&#xff1a;游戏、嵌入式、QT、客户端、服务端、机器学习、算法大模 型 ...&#xff0c;现阶段还是不太清楚具体想走什么方向。主QT编程应该是不在考虑之内的&#xff0c;可以为辅简单 学习一下&#xff1b;游戏方向&#xff1a;需要学习lua语言…...

【实战案例】Django框架表单处理及数据库交互

本文基于之前内容列表如下&#xff1a; 【图文指引】5分钟搭建Django轻量级框架服务 【实战案例】Django框架基础之上编写第一个Django应用之基本请求和响应 【实战案例】Django框架连接并操作数据库MySQL相关API 【实战案例】Django框架使用模板渲染视图页面及异常处理 更新编…...

python开发工具是选择vscode还是pycharm?两款软件优缺点对照!

Pycharm和VSCode是两款流行的代码编辑器&#xff0c;它们都有各自的优缺点和适用情况。本文将从以下几个方面对它们进行比较和分析&#xff1a; 功能和扩展性性能和稳定性用户体验和界面价格和支持 功能和扩展性 Pycharm是一款专为Python开发而设计的集成开发环境&#xff08;…...

2025选题|基于Hadoop的物品租赁系统的设计与实现

作者简介&#xff1a;Java领域优质创作者、CSDN博客专家 、CSDN内容合伙人、掘金特邀作者、阿里云博客专家、51CTO特邀作者、多年架构师设计经验、多年校企合作经验&#xff0c;被多个学校常年聘为校外企业导师&#xff0c;指导学生毕业设计并参与学生毕业答辩指导&#xff0c;…...

【Qt】QTableView添加下拉框过滤条件

实现通过带复选框的下拉框来为表格添加过滤条件 带复选框的下拉框 .h文件 #pragma once #include <QCheckBox> #include <QComboBox> #include <QEvent> #include <QLineEdit> #include <QListWidget>class TableComboBox : public QComboBox …...

部署DNS主从服务器

一。DNS主从服务器作用&#xff1a; DNS作为重要的互联网基础设施服务&#xff0c;保证DNS域名解析服务的正常运转至关重要&#xff0c;只有这样才能提供稳定、快速日不间断的域名查询服务 DNS 域名解析服务中&#xff0c;从服务器可以从主服务器上获取指定的区域数据文件&…...

从可逆计算看低代码

2020年低代码&#xff08;LowCode&#xff09;这一buzzword频繁亮相于主流技术媒体&#xff0c;大背景下是微软/亚马逊/阿里/华为等巨头纷纷入场&#xff0c;推出自己的相应产品。一时之间&#xff0c;大大小小的技术山头&#xff0c;无论自己原先是搞OA/ERP/IOT/AI的&#xff…...

设计模式最佳实践代码总结 - 结构型设计模式篇 - 侨接设计模式最佳实践

目录 侨接设计模式最佳实践 侨接设计模式最佳实践 桥接模式是一种结构型设计模式&#xff0c;它将抽象部分与它的实现部分分离&#xff0c;使它们可以独立地变化。桥接模式是一种结构型设计模式&#xff0c;它将抽象部分与它的实现部分分离&#xff0c;使它们可以独立地变化。…...

【软件测试】python——Unittest

UnitTest 框架 笔记来自于黑马程序员python自动化测试教程&#xff0c;python从基础到Uinttest框架管理测试用例。链接&#xff1a;[黑马程序员python自动化测试教程&#xff0c;python从基础到Uinttest框架管理测试用例](https://www.bilibili.com/video/BV1av411q7dT?spm_i…...

Maven:详解 clean 和 install 命令的使用

clean 的主要功能是清理项目构建过程中生成的所有临时文件和输出文件。具体来说&#xff0c;clean 阶段会删除 target 目录及其所有内容。 clean 阶段的具体功能 删除 target 目录&#xff1a; target 目录是 Maven 构建过程中默认的输出目录&#xff0c;存放所有构建生成的文件…...

HTTP与RPC

一、概念 HTTP&#xff08;Hypertext Transfer Protocol,超文本传输协议&#xff09;是一种应用层协议&#xff0c;主要用于在Web服务器之间传输html页面和其他Web资源。 RPC&#xff08;Remote Procedure Call&#xff0c;远程过程调用) 是一种通用的远程调用通信协议&#…...

解决蓝牙键盘按键错乱的问题

最近发现我的蓝牙键盘按下的键盘与实际不符&#xff0c;于是就上网搜索答案&#xff0c;网上的方法都试了一遍 最后想着准备退货&#xff0c;没想到客服直接给我解决了 原因很简单&#xff0c;就是之前误触了键盘的某些按键导致的 每个键盘品牌的按键因该都不同的&#xff0c;可…...

MiL.k X Biggie 奇妙宇宙来袭!

MiL.k 和亚航奖励计划联手推出 MiL.k X BIGGIE 奇妙宇宙&#xff0c;为亚航会员和 MiL.k 用户提供神奇的 Web3 体验。这款沉浸式体验位于 The Sandbox 的 MiL.k Land&#xff0c;提供趣味游戏&#xff0c;解锁令人兴奋的新奖励。 亚航吉祥物 BIGGIE 和他友好的机舱服务员将引导…...

云服务器中删除非空目录(包含文件和子目录)rm -rf <directory_name>

在云服务器中删除目录可以使用 rm 命令。如果您需要删除一个非空目录&#xff08;包含文件和子目录&#xff09;&#xff0c;可以使用以下命令&#xff1a; rm -rf <directory_name>参数解释&#xff1a; -r&#xff1a;递归删除&#xff0c;即删除目录及其所有内容&am…...

1991-2024年经管类国自然、国社科立项名单(附68份国自然标书)-最新出炉 附下载链接

很全&#xff01;1991-2024年经管类国自然、国社科立项名单&#xff08;附68份国自然标书&#xff09; 下载链接-点它&#x1f449;&#x1f449;&#x1f449;&#xff1a;很全1991-2024年经管类国自然、国社科立项名单&#xff08;附68份国自然标书&#xff09;.zip 资源介…...

Flutter问题记录 - 布局中莫名其妙的白线/缝隙

文章目录 前言开发环境问题描述问题分析解决方案最后 前言 最近客服反馈了一个奇怪的问题&#xff0c;有个用户反馈其他问题时给了应用截图&#xff0c;然后他发现这截图中有一条奇怪的白线。他在自己手机上没有发现这个问题&#xff0c;于是提工单反馈到我这。 开发环境 Fl…...

从零学习大模型(七)-----LoRA(中)

自注意力层中的 LoRA 应用 Transformer 的自注意力机制是模型理解输入序列之间复杂关系的核心部分。自注意力层通常包含多个线性变换&#xff0c;包括键&#xff08;Key&#xff09;、查询&#xff08;Query&#xff09; 和 值&#xff08;Value&#xff09; 三个权重矩阵的线…...

Java知识巩固(十二)

I/O JavaIO流了解吗&#xff1f; IO 即 Input/Output&#xff0c;输入和输出。数据输入到计算机内存的过程即输入&#xff0c;反之输出到外部存储&#xff08;比如数据库&#xff0c;文件&#xff0c;远程主机&#xff09;的过程即输出。数据传输过程类似于水流&#xff0c;因…...

一家光伏企业终止,恐不具行业代表性,市占率仅为2.35%

海达光能终止原因如下&#xff1a;报告期内海达光能销售金额较所在行业第二名亚玛顿相差两倍以上&#xff0c;公司毛利率更是远低于行业龙头福莱特&#xff0c;恐难以说明公司行业代表性。在企业竞争上&#xff0c;公司2021年度的市场占有率约为2.35%&#xff0c;公司未来光伏玻…...

排查华为USG防火墙上不了网?先检查这5个配置点(附真实配置案例)

华为USG防火墙上网故障排查实战指南 当内网用户突然无法访问互联网时&#xff0c;作为运维人员往往会面临巨大的压力。华为USG防火墙作为企业网络的核心安全设备&#xff0c;其配置的每一个细节都可能成为网络连通性的关键。本文将从一个真实的故障排查案例出发&#xff0c;带您…...

AMBA 3 AXI协议架构解析与工程实践

1. AMBA 3 AXI协议架构解析AMBA 3 AXI协议作为ARM推出的第三代高级可扩展接口&#xff0c;其架构设计充分考虑了现代SoC对高带宽和低延迟的核心需求。与传统的AMBA 2 AHB协议相比&#xff0c;AXI通过五项关键技术革新实现了性能的质的飞跃&#xff1a;1.1 五通道分离式架构AXI协…...

反射式红外光电管ITR9909:从基础测试到智能车竞赛应用实战

1. ITR9909反射式红外光电管基础入门 第一次拿到ITR9909这个小家伙时&#xff0c;我差点被它朴素的外表骗了。这个直径不到5mm的黑色塑料封装器件&#xff0c;看起来就像普通的三极管&#xff0c;但它的能力可不容小觑。作为智能车竞赛的老玩家&#xff0c;我发现它在信标检测…...

WarcraftHelper:让魔兽争霸3在现代电脑重获新生的终极解决方案

WarcraftHelper&#xff1a;让魔兽争霸3在现代电脑重获新生的终极解决方案 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为魔兽争霸3在Windows …...

用Logisim搞定Educoder实训:从数码管驱动到完整交通灯系统的保姆级通关攻略

Logisim实战&#xff1a;从数码管驱动到交通灯系统的Educoder通关全解析 第一次打开Educoder平台的《交通灯系统设计》实训项目时&#xff0c;我和大多数同学一样&#xff0c;面对十二个关卡的层层递进有些手足无措。经过三个通宵的调试和无数次的电路重构&#xff0c;终于摸索…...

别再到处找靶场了!一个OWASP BWA虚拟机搞定30+个Web漏洞环境(附SSH连接与MySQL密码修改指南)

OWASP BWA&#xff1a;一站式Web安全实战环境的终极解决方案 对于Web安全初学者和爱好者来说&#xff0c;寻找合适的漏洞靶场往往比学习技术本身更令人头疼。你是否也曾在不同平台间反复切换&#xff0c;下载各种零散的虚拟机镜像&#xff0c;只为练习一个简单的SQL注入或XSS漏…...

Equalizer APO完整教程:免费系统级音频均衡器从入门到精通

Equalizer APO完整教程&#xff1a;免费系统级音频均衡器从入门到精通 【免费下载链接】equalizerapo Equalizer APO mirror 项目地址: https://gitcode.com/gh_mirrors/eq/equalizerapo Equalizer APO是一款功能强大的免费开源系统级音频均衡器软件&#xff0c;能够为W…...

目标检测:YOLOv12训练自己的数据集,手把手教学一看就会

目录 1. 环境配置 2. 数据集 2.1 网上搜索公开数据集 2.1.1 搜索引擎 2.1.2 Kaggle 2.1.3 Roboflow 2.2 自制数据集 2.2.1 Labelimg安装 2.2.2 Labelimg使用 2.3 数据集转换及划分 2.3.1 数据集VOC格式转yolo格式 2.3.2 数据集划分 3. 训练模型 3.1 创建data.yam…...

别再死记硬背了!用Pointer Network搞定NLP里的OOV难题(附代码实战)

Pointer Network实战&#xff1a;如何优雅解决NLP中的OOV难题 在电商客服机器人开发中&#xff0c;你是否遇到过这样的尴尬场景&#xff1a;当用户询问"冰墩墩什么时候补货"时&#xff0c;机器人却回复"该商品暂无库存"——它完全没理解"冰墩墩"…...

关于python

1.python的主要运用Python的主要应用领域Python作为一种通用编程语言&#xff0c;因其简洁、易读和强大的生态系统&#xff0c;被广泛应用于多个领域。以下是Python的主要应用场景&#xff1a;数据科学与机器学习Python在数据分析和机器学习领域占据主导地位。库如NumPy、Panda…...