数组处理方法总结:改变与不改变原数组

2024-09-06 14:36

本文主要是介绍数组处理方法总结:改变与不改变原数组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近在写项目处理数组对象的时候,有时候会思考如何快速简洁的实现数据的处理,但在使用的时候,会误解一些不常用的数组方法的意思,导致数据处理结果不对,然后就总结了一份常用的数组处理方法
改变原数组的方法: push()、pop()、shift()、unshift()、splice()、reverse()、sort()、copyWithin()、fill()。
不改变原数组的方法: concat()、slice()、map()、filter()、reduce()、reduceRight()、join()、includes()、indexOf()、find()、findIndex()、every()、some()。

一、改变原数组的方法

1、push(): 向数组末尾添加一个或多个元素。

let arr = [1, 2, 3];
arr.push(4); // [1, 2, 3, 4]

pop(): 移除数组末尾的元素,并返回该元素。

let arr = [1, 2, 3];
arr.pop(); // 返回 3, arr 变成 [1, 2]

shift(): 移除数组的第一个元素,并返回该元素。

let arr = [1, 2, 3];
arr.shift(); // 返回 1, arr 变成 [2, 3]

unshift(): 向数组的开头添加一个或多个元素,并返回新的长度。

let arr = [1, 2, 3];
arr.unshift(0); // 返回 4, arr 变成 [0, 1, 2, 3]

splice(): 从数组中删除、替换或添加元素,直接修改原数组。在这里插入代码片

let arr = [1, 2, 3, 4];
arr.splice(1, 2, 10); // 删除 1 个元素并插入 10, arr 变成 [1, 10, 4]

reverse(): 颠倒数组的顺序。

let arr = [1, 2, 3];
arr.reverse(); // [3, 2, 1]

sort(): 对数组进行排序,默认按字母顺序。可以传入比较函数。

let arr = [3, 1, 2];
arr.sort(); // [1, 2, 3]

copyWithin(): 在当前数组中,复制数组的一部分到另一个位置(会改变原数组)。

let arr = [1, 2, 3, 4, 5];
arr.copyWithin(0, 3); // [4, 5, 3, 4, 5]

fill(): 用指定值填充数组中的部分或所有元素。

let arr = [1, 2, 3];
arr.fill(0); // [0, 0, 0]

二、不改变原数组的方法

concat(): 合并两个或多个数组,返回一个新数组。

let arr1 = [1, 2];
let arr2 = [3, 4];
let newArr = arr1.concat(arr2); // [1, 2, 3, 4]

slice(): 返回数组的一个浅拷贝,指定起始和结束位置(不包括结束位置)。

let arr = [1, 2, 3, 4];
let newArr = arr.slice(1, 3); // [2, 3]

map(): 通过对数组中的每个元素执行一个函数,返回一个新数组。

let arr = [1, 2, 3];
let newArr = arr.map(x => x * 2); // [2, 4, 6]

filter(): 创建一个新数组,包含通过测试的所有元素。

let arr = [1, 2, 3, 4];
let newArr = arr.filter(x => x > 2); // [3, 4]

reduce(): 对数组的每个元素执行累加器函数,最终返回一个值。

let arr = [1, 2, 3];
let sum = arr.reduce((acc, curr) => acc + curr, 0); // 6

reduceRight(): 类似于 reduce(),但从右到左执行。

let arr = [1, 2, 3];
let sum = arr.reduceRight((acc, curr) => acc + curr, 0); // 6

join(): 将数组中的所有元素连接成一个字符串。

let arr = [1, 2, 3];
let str = arr.join("-"); // "1-2-3"

includes(): 检查数组是否包含某个值,返回布尔值。

let arr = [1, 2, 3];
arr.includes(2); // true

indexOf(): 返回数组中首次出现指定值的索引,如果未找到则返回 -1。

let arr = [1, 2, 3];
arr.indexOf(2); // 1

find(): 返回数组中第一个通过测试的元素。

let arr = [1, 2, 3];
let found = arr.find(x => x > 1); // 2

findIndex(): 返回数组中第一个通过测试的元素的索引。

let arr = [1, 2, 3];
let index = arr.findIndex(x => x > 1); // 1

every(): 检查数组中的每个元素是否都通过测试,返回布尔值。

let arr = [1, 2, 3];
arr.every(x => x > 0); // true

some(): 检查数组中是否至少有一个元素通过测试,返回布尔值。

let arr = [1, 2, 3];
arr.some(x => x > 2); // true

这篇关于数组处理方法总结:改变与不改变原数组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142284

相关文章

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

Go路由注册方法详解

《Go路由注册方法详解》Go语言中,http.NewServeMux()和http.HandleFunc()是两种不同的路由注册方式,前者创建独立的ServeMux实例,适合模块化和分层路由,灵活性高... 目录Go路由注册方法1. 路由注册的方式2. 路由器的独立性3. 灵活性4. 启动服务器的方式5.

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

Spring排序机制之接口与注解的使用方法

《Spring排序机制之接口与注解的使用方法》本文介绍了Spring中多种排序机制,包括Ordered接口、PriorityOrdered接口、@Order注解和@Priority注解,提供了详细示例... 目录一、Spring 排序的需求场景二、Spring 中的排序机制1、Ordered 接口2、Pri

Idea实现接口的方法上无法添加@Override注解的解决方案

《Idea实现接口的方法上无法添加@Override注解的解决方案》文章介绍了在IDEA中实现接口方法时无法添加@Override注解的问题及其解决方法,主要步骤包括更改项目结构中的Languagel... 目录Idea实现接China编程口的方法上无法添加@javascriptOverride注解错误原因解决方

MySql死锁怎么排查的方法实现

《MySql死锁怎么排查的方法实现》本文主要介绍了MySql死锁怎么排查的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言一、死锁排查方法1. 查看死锁日志方法 1:启用死锁日志输出方法 2:检查 mysql 错误

Java通过反射获取方法参数名的方式小结

《Java通过反射获取方法参数名的方式小结》这篇文章主要为大家详细介绍了Java如何通过反射获取方法参数名的方式,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、解决方式方式2.1: 添加编译参数配置 -parameters方式2.2: 使用Spring的内部工具类 -

c++中std::placeholders的使用方法

《c++中std::placeholders的使用方法》std::placeholders是C++标准库中的一个工具,用于在函数对象绑定时创建占位符,本文就来详细的介绍一下,具有一定的参考价值,感兴... 目录1. 基本概念2. 使用场景3. 示例示例 1:部分参数绑定示例 2:参数重排序4. 注意事项5.

使用C++将处理后的信号保存为PNG和TIFF格式

《使用C++将处理后的信号保存为PNG和TIFF格式》在信号处理领域,我们常常需要将处理结果以图像的形式保存下来,方便后续分析和展示,C++提供了多种库来处理图像数据,本文将介绍如何使用stb_ima... 目录1. PNG格式保存使用stb_imagephp_write库1.1 安装和包含库1.2 代码解

Windows设置nginx启动端口的方法

《Windows设置nginx启动端口的方法》在服务器配置与开发过程中,nginx作为一款高效的HTTP和反向代理服务器,被广泛应用,而在Windows系统中,合理设置nginx的启动端口,是确保其正... 目录一、为什么要设置 nginx 启动端口二、设置步骤三、常见问题及解决一、为什么要设置 nginx